

Specifications are subject to change without notice. © 2022 Vango Technologies, Inc.

This document contains information that is proprietary to Vango Technologies, Inc. Unauthorized reproduction of this information in whole or in part is strictly prohibited. ARM $^{ extsf{R}}$ -based 32-bit Cortex $^{ extsf{R}}$ -M4F MCU + FPU, with 1024 Kbyte ~ 5120 Kbyte Internal Flash

Memory, USB, 17 Timers, ADCs, 17 Communication Interfaces

## Function

### ■ Core: ARM<sup>®</sup>32-bit Cortex<sup>®</sup>-M4F CPU with FPU

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

### Memory

- 1024 Kbytes (V8410N, V8410C, V8411S) or 5120 Kbytes (V8411N) of Flash instruction/data memory
- SPIM interface: (Only V8410C) Extra interfacing up to 16 Mbytes of external SPI Flash
- Up to 1024 or 640 Kbytes of SRAM
- External memory controller (XMC) with 2 Chip Select, supports multiplexed NOR/PSRAM and NAND memories
- LCD parallel interface, 8080/6800 modes

### Clock, Reset, and Power Management

- 2.6 V  $\sim$  3.6 V application supply and I/Os
- POR/ PDR, and programmable voltage detector (PVD)
- 4 to 25 MHz crystal oscillator
- Internal 48 MHz factory-trimmed RC (accuracy 1% at TA=25 °C, 2.5 % at TA=-40 to +85 °C)
- Internal 40 KHz RC oscillator
- 32 KHz oscillator with calibration

### ■ Low Power Consumption

- Sleep, Stop, and Standby modes
- $V_{BAT}$  supply for RTC and 64 x 16-bit backup registers
- 4 WKUP pins, which can wake up the standby mode

### ■ 1 12-bit A/D converters, 0.5 µs converting time (Up to 16 channels)

- Conversion range: 0 V to 3.6 V



- Triple sample and hold capability
- Temparature sensor

### DMA: 14 channel DMA controller

- Peripherals supported: timers, ADC, I2S, SPI, I2C, and USART

#### Debug Mode

- Serial Wire Debug (SWD) and JTAG interface

### ■ Up to 80 Fast I/O Interfaces

- 80 multifunctional and bidirectional I/Os, all mappable to 16 external interrupt vectors and almost

5 V-tolerant

– All fast I/Os, control registers accessable with  $f_{AHB}$  speed

### ■ Up to 17 Timers

- Up to 8 x 16-bit timers + 2 x 32-bit timers; each with 4 input capture/ output comparison/PWM

or pulse counter and quadrature (incremental) encoder input.

- Up to 2 x 16-bit motor control PWM advanced timers with dead-time generator and emergency stop
- 2 x Watchdog timers (independent and window)
- SysTick timer: 24-bit downcounter
- 2 x 16-bit basic timers

### ■ Up to 17 Communication Interfaces

- Up to 3 x I2C interfaces (SMBus/ PMBus)
- Up to 8 x USARTs (ISO7816 interface, LIN, IrDA capability, and modem control)
- Up to 4 x SPIs (36 Mbit/s), all with I2S interface multiplexed
- CAN interface (2.0B Active)
- USB2.0 full-speed interface

### CRC Calculation Unit

### Packaging

- LQFP128 14x14 mm (V8410C)
- LQFP100 14x14 mm (V8410N, V8411N)
- LQFP48 7x7 mm (V8411S)



### List of Models

| Internal Flash Memory | SPIM        | model  |
|-----------------------|-------------|--------|
| 1024 Kbytes           | Not support | V8410N |
| 5120 Kbytes           | Not support | V8411N |
| 1024 Kbytes           | Not support | V8411S |
| 1024 Kbytes           | support     | V8410C |



## **Table of Contents**

| Man          |                                             | / 782 |
|--------------|---------------------------------------------|-------|
| 3.3.1        | Clock Control Register (RCC_CTRL)           |       |
| 3.3          | RCC Registers Description                   |       |
| 3.2.10       | Clock-out Capability                        |       |
| 3.2.9        | Watchdog Clock                              |       |
| 3.2.8        | RTC Clock                                   |       |
| 3.2.7        | Clock Failure Detection (CFD)               |       |
| 3.2.6        | System Clock (SYSCLK) Selection             |       |
| 3.2.5        | LSI Clock                                   |       |
| 3.2.4        | LSE Clock                                   |       |
| 3.2.3        | PLL                                         |       |
| 3.2.2        | HSI Clock                                   |       |
| 3.2.1        | HSE Clock                                   |       |
| 3.2          | Clocks                                      |       |
| 3.1.3        | Backup Domain Reset                         |       |
| 3.1.2        | Power Reset                                 |       |
| 3.1.1        | System Reset                                |       |
| 3.1          | Reset                                       |       |
| 3            | Reset and Clock Control (RCC)               |       |
| 2.4.2        | Power Control/Status Register (PWR_CTRLSTS) |       |
| 2.4.1        | Power Control Register (PWR_CTRL)           |       |
| 2.4          | PWR Registers                               |       |
| 2.3.3        | Auto-wakeup (AWU)                           |       |
| 2.3.2        | Low-power Mode                              |       |
| 2.3.1        | Power Supply                                |       |
| 2.3          | Function Overview                           |       |
| 2.2          | Main Features                               |       |
| 2.1          | Introduction                                |       |
| 2            | Power Control (PWR)                         |       |
| 1.4.2        | Flash Memory Size Register                  |       |
| 1.4.1        | Description of Register Abbreviations       | 39    |
| 1.4          | Device Characteristics Information          | 39    |
| 1.3          | Boot Configuration                          | 38    |
| 1.2.4        | On-chip Flash                               | 33    |
| 1.2.3        | On-chip SRAM                                | 32    |
| 1.2.2        | Bit Banding                                 | 32    |
| 1.2.1        | Register Map                                | 28    |
| 1.2          | Address Map                                 |       |
| 1.1.2        | ARM Cortex®-M4F Processer                   | 26    |
| 1.1.1        | Bus Architecture                            |       |
| 1.1          | System Introduction                         |       |
| 1            | System Architecture                         |       |
| Revision His | story                                       | 23    |
| Table        |                                             | 20    |
| Figure       |                                             | 14    |
| Table of Cor | ntents                                      | 5     |
| Function     |                                             | 2     |

| 3.3.2           | Clock Configuration Register (RCC_CFG)                                                            | 68 |
|-----------------|---------------------------------------------------------------------------------------------------|----|
| 3.3.3           | Clock Interrupt Register (RCC_CLKINT)                                                             | 72 |
| 3.3.4           | APB2 Peripheral Reset Register (RCC_APB2RST)                                                      | 76 |
| 3.3.5           | APB1 Peripheral Reset Register (RCC_APB1RST)                                                      | 78 |
| 3.3.6           | AHB Peripheral Clock Enable Register (RCC_AHBEN)                                                  | 82 |
| 3.3.7           | APB2 Peripheral Clock Enable Register (RCC_APB2EN)                                                | 84 |
| 3.3.8           | APB1 Peripheral Clock Enable Register (RCC_APB1EN)                                                | 87 |
| 3.3.9           | Backup Domain Control Register (RCC_BDC)                                                          | 91 |
| 3.3.10          | Control/Status register (RCC_CTRLSTS)                                                             | 92 |
| 3.3.11          | Additional Register (RCC_MISC)                                                                    |    |
| 3.3.12          | Test Register (RCC_TEST)                                                                          |    |
| 3.3.13          | Additional Register (RCC_MISC2)                                                                   |    |
| 3.3.14          | Additional Register (RCC_INTCTRL)                                                                 | 97 |
| 4               | Backup Registers (BKPR)                                                                           | 98 |
| 4.1             | BKPR Introduction                                                                                 |    |
| 4.2             | BKPR Main Features                                                                                |    |
| 4.3             | BKPR Function Overview                                                                            |    |
| 4.3.1           | Tamper Detection                                                                                  |    |
| 4.3.2           | RTC Calibration                                                                                   |    |
| 4.4             | BKPR Registers                                                                                    |    |
| 4.4.1           | Backup Data Register x (BKPR_DRx) (x = 1,, 64)                                                    |    |
| 4.4.2           | RTC Clock Calibration Register (BKPR_RTCCAL) 1                                                    |    |
| 4.4.3           | Backup Control Register (BKPR_CTRL) 1                                                             |    |
| 4.4.4           | Backup Control/Status Register (BKPR_CTRLSTS) 1                                                   |    |
| 5               | Flash Memory Controller (FMC) 1                                                                   |    |
| 5.1             | FMC Introduction                                                                                  | -  |
| 5.2             | Main Features                                                                                     |    |
| 5.2.1           | Flash Memory Architecture 1                                                                       |    |
| 5.2.2           | The third flash memory (V8411N Bank3)1                                                            |    |
| 5.2.3           | External Flash Memory Organization (V8410C bank3) 1                                               |    |
| 5.3             | Function Overview                                                                                 |    |
| 5.3.1           | Read Operation                                                                                    |    |
| 5.3.2           | Flash Program/Erase Controller (FPEC)                                                             |    |
| 5.3.3           | Protection                                                                                        |    |
| 5.3.4           | Option Byte Description                                                                           |    |
| 5.4             | FMC Registers                                                                                     |    |
| 5.4.1           | Flash Access Control Register (FLASH_ACR)                                                         |    |
| 5.4.2           | FPEC Key Register (FLASH_FCKEY)       1         First OPT/(F)/ Desister (FLASH_OPT/(F)/D)       1 |    |
| 5.4.3           | Flash OPTKEY Register (FLASH_OPTKEYR)                                                             |    |
| 5.4.4<br>5.4.5  | Flash Status Register (FLASH_STS)                                                                 |    |
| 5.4.5<br>5.4.6  | Flash Control Register (FLASH_CTRL)       1         Flash Address Register (FLASH_ADDR)       1   |    |
| 5.4.7           | Option Byte Register (FLASH_UOB)                                                                  |    |
| 5.4.8           | Write Protection Register (FLASH_WRPRT)                                                           |    |
| 5.4.8<br>5.4.9  | FPEC Key Register 2 (FLASH_FCKEY2)                                                                |    |
| 5.4.9<br>5.4.10 | Flash Status Register 2 (FLASH_STS2)                                                              |    |
| 5.4.10          | Flash Control Register 2 (FLASH_CTRL2)                                                            |    |
| 5.4.12          | Flash Address Register 2 (FLASH_ADDR2)                                                            |    |
|                 | FPEC Key Register 3 (FLASH_FCKEY3)                                                                |    |
| 5.4.13          |                                                                                                   | 52 |

| 5.4.14 | Flash Option Byte Register (FLASH_SELECT)                           | 133 |
|--------|---------------------------------------------------------------------|-----|
| 5.4.15 | Flash Status Register 3 (FLASH_STS3)                                | 133 |
| 5.4.16 | Flash Control Register 3 (FLASH_CTRL3)                              | 134 |
| 5.4.17 | Flash Address Register 3 (FLASH_ADDR3)                              | 135 |
| 5.4.18 | Flash Decode Address Register (FLASH_DA)                            | 136 |
| 5.4.19 | Flash Memory CRC Calibration Control Register (CRC_DR)              | 137 |
| 5.4.20 | Flash Memory CRC Calibration Result Register (CRC_OUTR)             | 137 |
| 6      | CRC Calculation Unit (CRC)                                          | 139 |
| 6.1    | CRC Introduction                                                    | 139 |
| 6.2    | CRC Main Features                                                   | 139 |
| 6.3    | CRC Function Overview                                               | 140 |
| 6.4    | CRC Registers                                                       | 140 |
| 6.4.1  | Data Register (CRC_DR)                                              | 140 |
| 6.4.2  | Independent Data Register (CRC_IDR)                                 | 140 |
| 6.4.3  | Control Register (CRC_CTRL)                                         | 141 |
| 7      | General-purpose and Alternate-function I/Os (GPIOs and AFIOs)       | 142 |
| 7.1    | Introduction                                                        | 142 |
| 7.2    | Main Features                                                       | 142 |
| 7.3    | Function Overview                                                   | 143 |
| 7.3.1  | GPIO Pin Configuration                                              | 143 |
| 7.3.2  | External Interrupt/Wakeup Lines                                     | 146 |
| 7.3.3  | Input Configuration                                                 | 146 |
| 7.3.4  | Analog Input Configuration                                          | 147 |
| 7.3.5  | Output Configuration                                                | 147 |
| 7.3.6  | GPIO Locking Mechanism                                              | 148 |
| 7.3.7  | Alternate Function (AF)                                             | 149 |
| 7.4    | IO Mapping Function Configuration                                   | 154 |
| 7.4.1  | OSC32_IN/OSC32_OUT as GPIO Interface PC14/ PC15                     | 154 |
| 7.4.2  | CAN Alternate Function Remapping                                    | 154 |
| 7.4.3  | JTAG/SWD Alternate Function Remapping                               | 154 |
| 7.4.4  | ADC Alternate Function Remapping                                    | 155 |
| 7.4.5  | Timer Alternate Function Remapping                                  | 156 |
| 7.4.6  | USART Alternate Function Remapping                                  | 158 |
| 7.4.7  | I <sup>2</sup> C Alternate Function Remapping                       | 160 |
| 7.4.8  | SPI/ I2S Alternate Function Remapping                               | 160 |
| 7.4.9  | XMC Alternate Function Remapping                                    | 162 |
| 7.5    | GPIO and AFIO Registers                                             | 162 |
| 7.5.1  | Port Configuration Register Low (GPIOx_CTRLL) (x = AE)              | 162 |
| 7.5.2  | Port Configuration Register High (GPIOx_CTRLH) (AE)                 | 163 |
| 7.5.3  | Port Input Data Register (GPIOx_IPTDT) (x = AE)                     | 164 |
| 7.5.4  | Port Output Data Register (GPIOx_OPTDT) (x = AE)                    | 165 |
| 7.5.5  | Port Bit Set/Reset Register (GPIOx_BSRE) (x = AE)                   | 165 |
| 7.5.6  | Port Bit Reset Register (IOx_BRE) (x = AE)                          | 166 |
| 7.5.7  | Port Configuration Lock Register (GPIOx_LOCK) (x = AE)              | 166 |
| 7.5.8  | Slew Rate Control Register (GPIOx_SRCTR) (x = AE)                   | 167 |
| 7.5.9  | Port Huge Driven Control Register (GPIOx_HDRV) (x = AE)             | 168 |
| 7.5.10 | Alternate Event Control Register (AFIO_EVCTRL)                      | 168 |
| 7.5.11 | AF Remap and Debug I/O Configuration Register (AFIO_MAP)            |     |
| 7.5.12 | Alternate External Interrupt Configuration Register 1 (AFIO_EXTIC1) | 174 |

| 7.5.13 | Alternate External Interrupt Configuration Register 2 (AFIO_EXTIC2)       | 175 |
|--------|---------------------------------------------------------------------------|-----|
| 7.5.14 | Alternate External Interrupt Configuration Register 3 (AFIO_EXTIC3)       | 175 |
| 7.5.15 | Alternate External Interrupt Configuration Register 4 (AFIO_EXTIC4)       | 176 |
| 7.5.16 | AF Remap and Debug I/O Configuration Register 2 (AFIO_MAP2)               | 176 |
| 7.5.17 | AF Remap and Debug I/O Configuration Register 3 (AFIO_MAP3)               | 178 |
| 7.5.18 | AF Remap and Debug I/O Configuration Register 4 (AFIO_MAP4)               | 178 |
| 7.5.19 | AF Remap and Debug I/O Configuration Register 5 (AFIO_MAP5)               | 179 |
| 7.5.20 | AF Remap and Debug I/O Configuration Register 6 (AFIO_MAP6)               | 181 |
| 7.5.21 | AF Remap and Debug I/O Configuration Register 7 (AFIO_MAP7)               | 182 |
| 7.5.22 | AF Remap and Debug I/O Configuration Register 8 (AFIO_MAP8)               | 183 |
| 8      | Interrupts and Events                                                     | 185 |
| 8.1    | Nested Vectored Interrupt Controller                                      | 185 |
| 8.1.1  | Features                                                                  | 185 |
| 8.1.2  | System Tick (SysTick) Calibration Value Register                          | 185 |
| 8.1.3  | Interrupt and Exception Vectors                                           | 185 |
| 8.2    | External Interrupt/Event Controller (EXTI)                                | 190 |
| 8.2.1  | Main Features                                                             | 190 |
| 8.2.2  | Block Diagram                                                             | 191 |
| 8.2.3  | Wakeup Event Management                                                   | 191 |
| 8.2.4  | Function Overview                                                         | 192 |
| 8.2.5  | External Interrupt/Event Line Mapping                                     | 193 |
| 8.3    | EXTI Registers Description                                                | 194 |
| 8.3.1  | Interrupt Mask Register (EXTI_INTEN)                                      | 194 |
| 8.3.2  | Event Mask Register (EXTI_EVTEN)                                          | 194 |
| 8.3.3  | Rising Edge Trigger Selection Register (EXTI_RTRSEL)                      | 194 |
| 8.3.4  | Falling Edge Trigger Selection Register (EXTI_FTRSEL)                     |     |
| 8.3.5  | Software Interrupt Event Register (EXTI_SWIE)                             | 195 |
| 8.3.6  | Pending Register (EXTI_PND)                                               | 196 |
| 9      | DMA Controller (DMA)                                                      | 197 |
| 9.1    | DMA Introduction                                                          |     |
| 9.2    | DMA Main Features                                                         | 197 |
| 9.3    | Function Overview                                                         | 198 |
| 9.3.1  | DMA Transaction                                                           | 198 |
| 9.3.2  | Arbiter                                                                   | 199 |
| 9.3.3  | DMA Channels                                                              | 199 |
| 9.3.4  | Programmable Data Transfer Width, Alignment, and Endian                   | 201 |
| 9.3.5  | Error Management                                                          |     |
| 9.3.6  | Interrupts                                                                | 205 |
| 9.3.7  | DMA Request Mapping                                                       |     |
| 9.3.8  | DMA Flexible Request Mapping                                              |     |
| 9.4    | DMA Registers                                                             |     |
| 9.4.1  | DMA Interrupt Status Register (DMA_ISTS)                                  |     |
| 9.4.2  | DMA Interrupt Flag Clear Register (DMA_ICLR)                              |     |
| 9.4.3  | DMA Channel x Configuration Register (DMA_CHCTRLx) (x = 1 7)              |     |
| 9.4.4  | DMA Channel x Number of Data Register (DMA_TCNTx) ( $x = 1 \dots 7$ )     |     |
| 9.4.5  | DMA Channel x Peripheral Address Register (DMA_CPBAx) ( $x = 1 \dots 7$ ) |     |
| 9.4.6  | DMA Channel x Memory Address Register (DMA_CMBAx) ( $x = 1 \dots 7$ )     |     |
| 9.4.7  | Channel Source Register 0 (DMA_SRC_SEL0)                                  |     |
| 9.4.8  | Channel Source Register 1 (DMA_SRC_SEL1)                                  |     |
|        |                                                                           |     |

| 10     | Timer                                                    |
|--------|----------------------------------------------------------|
| 10.1   | Basic Timer (TMR6 and TMR7) 219                          |
| 10.1.1 | TMR6 and TMR7 Introduction                               |
| 10.1.2 | TMR6 and TMR7 Main Features 219                          |
| 10.1.3 | TMR6 and TMR7 Function Overview 220                      |
| 10.1.4 | TMR6 and TMR7 Registers 226                              |
| 10.2   | General-purpose Timer (TMR2 to TMR5)                     |
| 10.2.1 | TMRx Introduction                                        |
| 10.2.2 | TMRx Main Function                                       |
| 10.2.3 | TMRx Function Overview                                   |
| 10.2.4 | TMRx Registers Description                               |
| 10.3   | General-purpose Timer (TMR9 to TMR14)                    |
| 10.3.1 | TMRx Introduction                                        |
| 10.3.2 | TMRx Main Function                                       |
| 10.3.3 | TMRx Function Overview                                   |
| 10.3.4 | TMR9 and TMR12 Register Description                      |
| 10.3.5 | TMR10, TMR11, TMR13, and TMR14 Registers Description     |
| 10.4   | Advanced-control Timer (TMR1 and TMR8)                   |
| 10.4.1 | TMR1 and TMR8 Introduction                               |
| 10.4.2 | TMR1 and TMR8 Main Features                              |
| 10.4.3 | TMR1 and TMR8 Function Overview                          |
| 10.4.4 | TMR1 and TMR8 Registers Description                      |
| 11     | Watchdog                                                 |
| 11.1   | Window Watchdog (WWDG)                                   |
| 11.1.1 | WWDG Introduction                                        |
| 11.1.2 | WWDG Main Features                                       |
| 11.1.3 | WWDG Function Overview                                   |
| 11.1.4 | How to Program Watchdog Timeout                          |
| 11.1.5 | Debug Mode                                               |
| 11.1.6 | Register Description                                     |
| 11.2   | Independent Watchdog (IWDG)                              |
| 11.2.1 | Introduction                                             |
| 11.2.2 | IWDG Main Features                                       |
| 11.2.3 | IWDG Function Overview                                   |
| 11.2.4 | IWDG Register Description                                |
| 12     | Real-time Clock (RTC)                                    |
| 12.1   | RTC Introduction                                         |
| 12.2   | Main Features                                            |
| 12.3   | Function Overview                                        |
| 12.3.1 | Introduction                                             |
| 12.3.2 | Reset Process                                            |
| 12.3.3 | Reading RTC Registers                                    |
| 12.3.4 | RTC Register Configuration                               |
| 12.3.5 | RTC Flag Assertion                                       |
| 12.4   | RTC Register Description                                 |
| 12.4.1 | RTC Control Register High (RTC_CTRLH)                    |
| 12.4.2 | RTC Control Register Low (RTC_CTRLL)                     |
| 12.4.3 | RTC Prescaler Load Register (RTC_DIVH/RTC_DIVL)          |
| 12.4.4 | RTC Prescaler Divider Register (RTC_DIVCNTH/RTC_DIVCNTL) |
| Man    |                                                          |
| Man    |                                                          |

| 12.4.5  | RTC Counter Register (RTC_CNTH/RTC_CNTL) 45                      | 54          |
|---------|------------------------------------------------------------------|-------------|
| 12.4.6  | RTC Alarm Register (RTC_ALAH/RTC_ALAL) 45                        | 55          |
| 13      | Analog-to-Digital Converter (ADC) 45                             | 56          |
| 13.1    | ADC Introduction                                                 | 56          |
| 13.2    | ADC Main Features                                                | 56          |
| 13.3    | ADC Function Overview                                            | 57          |
| 13.3.1  | ADC Switch 45                                                    | 58          |
| 13.3.2  | ADC Clock                                                        | 58          |
| 13.3.3  | Channel Selection                                                | 58          |
| 13.3.4  | Single Conversion Mode                                           | 59          |
| 13.3.5  | Continuous Conversion Mode                                       | 50          |
| 13.3.6  | Timing Diagram                                                   | 50          |
| 13.3.7  | Analog Watchdog                                                  | 51          |
| 13.3.8  | Scan Mode                                                        | 52          |
| 13.3.9  | Injected Channel Management 46                                   | 52          |
| 13.3.10 | Discontinuous Mode                                               | 54          |
| 13.3.11 | Calibration                                                      | <u> 5</u> 5 |
| 13.3.12 | Data Alignment                                                   | 56          |
| 13.3.13 | Programmable Channel Sample Time                                 | 57          |
| 13.3.14 | Conversion on External Trigger                                   | 57          |
| 13.3.15 | DMA Request                                                      |             |
| 13.3.16 | Temperature Sensor                                               |             |
| 13.3.17 | ADC Interrupts                                                   | 70          |
| 13.4    | ADC Registers                                                    | 71          |
| 13.4.1  | ADC Status Register (ADC_STS) 47                                 | 71          |
| 13.4.2  | ADC Control Register 1 (ADC_CTRL1)                               |             |
| 13.4.3  | ADC Control Register 2 (ADC_CTRL2)                               |             |
| 13.4.4  | ADC Sample Time Register 1 (ADC_SMPT1)                           |             |
| 13.4.5  | ADC Sample Time Register 2 (ADC_SMPT2)                           | 30          |
| 13.4.6  | ADC Injected Channel Data Offset Register x (ADC_JOFSx) (x = 14) | 30          |
| 13.4.7  | ADC Watchdog High Threshold Register (ADC_WHTR)                  |             |
| 13.4.8  | ADC Watchdog Low Threshold Register (ADC_WLTR)                   | 31          |
| 13.4.9  | ADC Regular Sequence Register 1 (ADC_RSQ1)                       | 31          |
| 13.4.10 | ADC Regular Sequence Register 2 (ADC_RSQ2)                       |             |
| 13.4.11 | ADC Regular Sequence Register 3 (ADC_RSQ3)                       |             |
| 13.4.12 | ADC Injected Sequence Register (ADC_JSQ)                         | 33          |
| 13.4.13 | ADC Injected Data Register x (ADC_JDORx) ( $x = 14$ )            |             |
| 13.4.14 | ADC Regular Data Register (ADC_RDOR)                             | 35          |
| 14      | I <sup>2</sup> C Interface                                       |             |
| 14.1    | I <sup>2</sup> C Introduction                                    |             |
| 14.2    | I <sup>2</sup> C Main Features                                   | 36          |
| 14.3    | I <sup>2</sup> C Function Overview                               | 37          |
| 14.3.1  | Mode Selection                                                   | 37          |
| 14.3.2  | I <sup>2</sup> C Slave Mode                                      | 39          |
| 14.3.3  | I <sup>2</sup> C Master Mode                                     |             |
| 14.3.4  | Error Condition                                                  |             |
| 14.3.5  | SDA/SCL Line Control                                             |             |
| 14.3.6  | SMBus                                                            |             |
| 14.3.7  | DMA Request                                                      |             |
|         | •                                                                |             |
| Man     |                                                                  |             |

| 14.3.8  | Packet Error Checking (PEC)                                     | 506 |
|---------|-----------------------------------------------------------------|-----|
| 14.3.9  | I <sup>2</sup> C Interrupt Request                              | 507 |
| 14.3.10 | $I^2 C \ \text{Debug} \ \text{Mode} \ \ldots$                   | 508 |
| 14.4    | I <sup>2</sup> C Registers                                      | 509 |
| 14.4.1  | Control Register 1 (I2C_CTRL1)                                  | 509 |
| 14.4.2  | Control Register 2 (I2C_CTRL2)                                  | 512 |
| 14.4.3  | Own Address Register 1 (I2C_OADDR1)                             | 514 |
| 14.4.4  | Own Address Register 2 (I2C_OADDR2)                             | 515 |
| 14.4.5  | Data Register (I2C_DT)                                          | 515 |
| 14.4.6  | Status Register 1 (I2C_STS1)                                    | 516 |
| 14.4.7  | Status Register 2 (I2C_STS2)                                    | 521 |
| 14.4.8  | Clock Control Register (I2C_CLKCTRL)                            | 523 |
| 14.4.9  | TMRISE Register (I2C_TMRISE)                                    | 524 |
| 15      | Universal Synchronous/Asynchronous Receiver/Transmitter (USART) | 526 |
| 15.1    | USART Introduction                                              | 526 |
| 15.2    | USART Main Features                                             | 526 |
| 15.3    | USART Function Overview                                         | 528 |
| 15.3.1  | USART Feature Description                                       | 530 |
| 15.3.2  | Transmitter                                                     | 531 |
| 15.3.3  | Receiver                                                        | 535 |
| 15.3.4  | Fractional Baud Rate Generation                                 | 541 |
| 15.3.5  | USART Receiver's Tolerance to Clock Deviation                   | 543 |
| 15.3.6  | Multiprocessor Communication                                    | 544 |
| 15.3.7  | Parity Control                                                  | 546 |
| 15.3.8  | LIN (Local Interconnection Network) Mode                        | 547 |
| 15.3.9  | USART Synchronous Mode                                          | 549 |
| 15.3.10 | Single-wire Half-duplex Communication                           | 552 |
| 15.3.11 | Smartcard                                                       | 553 |
| 15.3.12 | IrDA SIR ENDEC Block                                            | 555 |
| 15.3.13 | Continuous Communication Using DMA                              | 557 |
| 15.3.14 | Hardware Flow Control                                           | 560 |
| 15.4    | USART Interrupt Request                                         | 562 |
| 15.5    | USART Mode Configuration                                        | 563 |
| 15.6    | USART Registers                                                 | 564 |
| 15.6.1  | Status Register (USART_STS)                                     | 564 |
| 15.6.2  | Data Register (USART_DT)                                        | 567 |
| 15.6.3  | Baud Rate Register (USART_BAUDR)                                |     |
| 15.6.4  | Control Register 1 (USART_CTRL1)                                |     |
| 15.6.5  | Control Register 2 (USART_CTRL2)                                | 571 |
| 15.6.6  | Control Register 3 (USART_CTRL3)                                |     |
| 15.6.7  | Guard Time and Prescaler Register (GTP)                         |     |
| 16      | Serial Peripheral Interface (SPI)                               |     |
| 16.1    | SPI Introduction                                                | 578 |
| 16.2    | Main Features                                                   | 578 |
| 16.2.1  | SPI Main Features                                               | 578 |
| 16.2.2  | I2S Function Overview                                           |     |
| 16.3    | Function Overview                                               |     |
| 16.3.1  | SPI Function Overview                                           |     |
| 16.3.2  | I2S Function Overview                                           | 603 |

| 16.4    | SPI Registers                                                  | 621 |
|---------|----------------------------------------------------------------|-----|
| 16.4.1  | SPI Control Register 1 (SPI_CTRL1) (Not Used in I2S Mode)      | 621 |
| 16.4.2  | SPI Control Register 2 (SPI_CTRL2)                             | 624 |
| 16.4.3  | SPI Status Register (SPI_STS)                                  | 626 |
| 16.4.4  | SPI Data Register (SPI_DT)                                     | 627 |
| 16.4.5  | SPI CRC Polynomial Register (SPI_CPOLY) (Not Used in I2S Mode) | 628 |
| 16.4.6  | SPIRxCRC Register (SPI_RCRC) (Not Used in I2S Mode)            | 629 |
| 16.4.7  | SPITxCRC Register (SPI_TCRC)                                   | 629 |
| 16.4.8  | SPI_I2S Configuration Register (SPI_I2SCTRL)                   | 630 |
| 16.4.9  | SPI_I2S Prescaler Register (SPI_I2SCLKP)                       | 632 |
| 17      | CAN Bus Controller                                             | 634 |
| 17.1    | Introduction                                                   | 634 |
| 17.2    | Main Features                                                  | 634 |
| 17.2.1  | Transmission                                                   | 634 |
| 17.2.2  | Reception                                                      | 634 |
| 17.2.3  | Time-triggered communication mode                              |     |
| 17.2.4  | Management                                                     |     |
| 17.2.5  | CAN SRAM Memory                                                |     |
| 17.3    | ,<br>Function Overview                                         |     |
| 17.3.1  | CAN Overall Function Description                               | 635 |
| 17.3.2  | Operating Mode                                                 |     |
| 17.3.3  | Test Mode                                                      |     |
| 17.3.4  | V84XXX in Debug Mode                                           |     |
| 17.3.5  | Transmission Handling                                          |     |
| 17.3.6  | Time-triggered Communication Mode                              |     |
| 17.3.7  | Reception Handling                                             |     |
| 17.3.8  | Identifier Filtering                                           |     |
| 17.3.9  | Message Storage                                                |     |
| 17.3.10 | Error Management                                               |     |
| 17.3.11 | Bit Timing                                                     |     |
| 17.3.12 | bxCAN Interrupt                                                |     |
| 17.4    | CAN Registers                                                  |     |
| 17.4.1  | Register Access Protection                                     |     |
| 17.4.2  | CAN Control and Status Register                                |     |
| 17.4.3  | CAN Mailbox Register                                           |     |
| 17.4.4  | CAN Filter Register                                            |     |
| 18      | External Memory Controller (XMC)                               |     |
| 18.1    | Introduction                                                   |     |
| 18.2    | Main Features                                                  | 683 |
| 18.2.1  | Block Diagram                                                  |     |
| 18.2.2  | AHB Interface                                                  |     |
| 18.2.3  | Supported Memories and Transactions                            | 684 |
| 18.3    | Function Overview                                              |     |
| 18.3.1  | Address Mapping                                                | 685 |
| 18.3.2  | NOR Flash/PSRAM Controller                                     |     |
| 18.3.3  | NAND Flash Controller                                          |     |
| 18.4    | XMC Registers                                                  |     |
| 18.4.1  | NOR Flash and PSRAM Controller Register                        |     |
| 18.4.2  | NAND Flash Controller Register                                 |     |
|         |                                                                |     |
| Man     |                                                                |     |

| 19     | Universal Serial Bus Full-speed Device Interface (USBDEV)          |
|--------|--------------------------------------------------------------------|
| 19.1   | Introduction                                                       |
| 19.2   | USB Main Features                                                  |
| 19.3   | Function Overview                                                  |
| 19.3.1 | USB Blocks Function Description                                    |
| 19.3.2 | Generic USB Device Programming743                                  |
| 19.4   | USB Registers                                                      |
| 19.4.1 | Common Registers                                                   |
| 19.4.2 | Endpoint Registers                                                 |
| 19.4.3 | Buffer Description Table Registers 772                             |
| 20     | MCU Debug (MCUDBG)775                                              |
| 20.1   | Introduction                                                       |
| 20.2   | Function Overview                                                  |
| 20.2.1 | Debug Support for Low-power Mode 777                               |
| 20.2.2 | Debug Support for Timer, Watchdog, bxCAN, and I <sup>2</sup> C 777 |
| 20.2.3 | ID Code                                                            |
| 20.2.4 | SWJ Debug Port Pins                                                |
| 20.2.5 | Internal pull-up and pull-down on JTAG pins 778                    |
| 20.3   | MCUDBG Registers                                                   |
| 20.3.1 | MCUDBG Control Register (MCUDBG_CTRL) 779                          |



## Figure

| Figure 1-1 V84XXX Series Microcontrollers System Architecture 24                           |
|--------------------------------------------------------------------------------------------|
| Figure 1-2 Internal Block Diagram of Cortex®-M4F22                                         |
| Figure 1-3 V84XXX Address Configuration28                                                  |
| Figure 2-1 Block Diagram of Each Power Supply4                                             |
| Figure 2-2 Power-on Reset/Power-down Reset Waveform                                        |
| Figure 2-3 PVD Threshold and Outputs43                                                     |
| Figure 3-1 Reset Circuit                                                                   |
| Figure 3-2 V84XXX Clock Tree                                                               |
| Figure 3-3 HSE/LSE Clock Sources                                                           |
| Figure 5-1 Programming process 110                                                         |
| Figure 5-2 Programming Process 112                                                         |
| Figure 5-3 Reference Circuit for External Memory 112                                       |
| Figure 5-4 Process of the Programming 115                                                  |
| Figure 5-5 Process of Flash Memory Page Erase 116                                          |
| Figure 5-6 Process of Flash Memory Mass Erase 117                                          |
| Figure 6-1 Block Diagram of CRC Calculation Unit 139                                       |
| Figure 7-1 Basic Structure of an I/O Port Bit 143                                          |
| Figure 7-2 Basic Structure of a 5-V Tolerant I/O Port Bit 144                              |
| Figure 7-3 Input Floating/Pull-up/Pull-down Configuration 146                              |
| Figure 7-4 High Impedance Analog Input Configuration 147                                   |
| Figure 7-5 Output Configuration 148                                                        |
| Figure 7-6 Alternate Function Configuration 150                                            |
| Figure 8-1 External Interrupt/Event Controller Block Diagram 192                           |
| Figure 8-2 External Interrupt GPIO Mapping 193                                             |
| Figure 9-1 DMA Block Diagram 197                                                           |
| Figure 9-2 DMA1 Request Mapping 206                                                        |
| Figure 9-3 DMA2 Request Mapping 202                                                        |
| Figure 10-1 Basic Timer Block Diagram 220                                                  |
| Figure 10-2 Counter Timing Diagram with Prescaler Division Changing from 1 to 2 222        |
| Figure 10-3 Counter Timing Diagram with Prescaler Division Changing from $1 \sim 4$ 222    |
| Figure 10-4 Counter Timing Diagram with Internal Clock Divided by 1                        |
| Figure 10-5 Counter Timing Diagram with Internal Clock Divided by 2 223                    |
| Figure 10-6 Counter Timing Diagram with Internal Clock Divided by 4 223                    |
| Figure 10-7 Counter Timing Diagram with Internal Clock Divided by N 224                    |
| Figure 10-8 Counter Timing Diagram with Update Event When ARPEN = 0 (TMRx_AR Not Preloaded |
|                                                                                            |
| Figure 10-9 Counter Timing Diagram with Update Event When ARPEN = 1 (TMRx_AR is Preloaded  |
|                                                                                            |
| Figure 10-10 Normal Mode Timing Diagram with Internal Clock Divided by 1                   |
| Figure 10-11 General-purpose Timer Block Diagram 232                                       |
| Figure 10-12 Counter Timing Diagram with Prescaler Division Changing from 1 to 2           |
| Figure 10-13 Counter Timing Diagram with Prescaler Division Changing from $1 \sim 4$ 234   |
| Figure 10-14 Counter Timing Diagram with Internal Clock Divided by 1                       |
| Figure 10-15 Counter Timing Diagram with Internal Clock Divided by 2                       |
| Figure 10-16 Counter Timing Diagram with Internal Clock Divided by 4                       |
| Figure 10-17 Counter Timing Diagram with Internal Clock Divided by N                       |
|                                                                                            |

| Figure 10-18 Counter Timing Diagram with Update Event When ARPEN = 0 (TMRx_AR Not Preloaded)   |
|------------------------------------------------------------------------------------------------|
|                                                                                                |
| Figure 10-19 Counter Timing Diagram with Update Event When ARPEN = 1 (TMRx_AR is Preloaded)    |
|                                                                                                |
| Figure 10-20 Counter Timing Diagram with Internal Clock Divided by 1                           |
| Figure 10-21 Counter Timing Diagram with Internal Clock Divided by 2                           |
| Figure 10-22 Counter Timing Diagram with Internal Clock Divided by 4                           |
| Figure 10-23 Counter Timing Diagram with Internal Clock Divided by N                           |
| Figure 10-24 Counter Timing Diagram with Update Event When ARPEN = 0                           |
| Figure 10-25 Counter Timing Diagram with Internal Clock Divided by 1, TMRx_AR = 0x6            |
| Figure 10-26 Counter Timing Diagram with Internal Clock Divided by 2                           |
| Figure 10-27 Counter Timing Diagram with Internal Clock Divided by 4, TMRx_AR = 0x36 243       |
| Figure 10-28 Counter Timing Diagram with Internal Clock Divided by N                           |
| Figure 10-29 Counter Timing Diagram with Update Event When ARPEN = 1 (Counter underflow)244    |
| Figure 10-30 Counter Timing Diagram with Update Event When $ARPEN = 1$ (Counter overflow). 245 |
| Figure 10-31 Control Circuit in Normal Mode with Internal Clock Divided by 1                   |
| Figure 10-32 TI2 External Clock Connection Example                                             |
| Figure 10-33 Control Circuit in External Clock Mode 1                                          |
| Figure 10-34 Block Diagram of External Trigger Input                                           |
| Figure 10-35 Control Circuit in External Clock Mode 2                                          |
| Figure 10-36 Capture/Compare Channel (e.g. Channel 1 Input Stage)                              |
| Figure 10-37 Capture/Compare Channel 1 Main Circuit                                            |
| Figure 10-38 Capture/Compare Channel Output Stage (Channel 1)                                  |
| Figure 10-39 PWM Input Mode Timing                                                             |
| Figure 10-40 Output Compare Mode, Toggle on OC1                                                |
| Figure 10-41 Edge-aligned PWM Waveforms (AR = 8)                                               |
| Figure 10-42 Center-aligned PWM Waveforms (AP = 8)                                             |
| Figure 10-43 Example of One-pulse Mode                                                         |
| Figure 10-44 Clearing OCxREF in TMRx                                                           |
| Figure 10-44 Clearing OCXXET III THXX                                                          |
| Figure 10-46 Example of Encoder Interface Mode with IC1FP1 Polarity Inverted                   |
| Figure 10-47 Control Circuit in Reset Mode                                                     |
| Figure 10-48 Control Circuit in Gated Mode                                                     |
| Figure 10-49 Control Circuit in Trigger Mode                                                   |
| Figure 10-50 Control Circuit in External Clock Mode 2 + Trigger Mode                           |
| Figure 10-51 Master/Slave Timer Example                                                        |
| Figure 10-52 Timer 1 OC1REF Controls Timer 2                                                   |
| Figure 10-52 Timer 1 OCTREF Controls Timer 2                                                   |
| Figure 10-54 Using Timer 1 Update to Trigger Timer 2                                           |
| Figure 10-55 Using Timer 1 Enable to Trigger Timer 2                                           |
|                                                                                                |
| Figure 10-56 Using Timer 1 TI1 Input to Trigger Timer 1 and Timer 2                            |
| Figure 10-57 Block Diagram of General-purpose Timer TMR9/12                                    |
| Figure 10-58 Block Diagram of General-purpose Timers TMR10/11/13/14                            |
| Figure 10-59 Counter Timing Diagram with Prescaler Division Changing from 1 to 2               |
| Figure 10-60 Counter Timing Diagram with Prescaler Division Changing from $1 \sim 4$           |
| Figure 10-61 Counter Timing Diagram with Internal Clock Divided by 1                           |
| Figure 10-62 Counter Timing Diagram with Internal Clock Divided by 2                           |
| Figure 10-63 Counter Timing Diagram with Internal Clock Divided by 4                           |
| Figure 10-64 Counter Timing Diagram with Internal Clock Divided by N                           |



| Figure 10-65 Counter Timing Diagram with Update Event When ARPEN = 0 (TMRx_AR Not Preload | -    |
|-------------------------------------------------------------------------------------------|------|
|                                                                                           |      |
| Figure 10-66 Counter Timing Diagram with Update Event When ARPEN = 1 (TMRx_AR is Preload  | -    |
|                                                                                           |      |
| Figure 10-67 Control Circuit in Normal Mode with Internal Clock Divided by 1              |      |
| Figure 10-68 TI2 External Clock Connection Example                                        |      |
| Figure 10-69 Control Circuit in External Clock Mode 1                                     |      |
| Figure 10-70 Capture/Compare Channel (e.g. Channel 1 Input Stage)                         |      |
| Figure 10-71 Capture/Compare Channel 1 Main Circuit                                       |      |
| Figure 10-72 Capture/Compare Channel Output Stage (Channel 1)                             |      |
| Figure 10-73 PWM Input Mode Timing                                                        |      |
| Figure 10-74 Output Compare Mode, Toggle on OC1                                           |      |
| Figure 10-75 Edge-aligned PWM Waveforms (AR = 8)                                          |      |
| Figure 10-76 Example of One-pulse Mode                                                    |      |
| Figure 10-77 Control Circuit in Reset Mode                                                |      |
| Figure 10-78 Control Circuit in Gated Mode                                                |      |
| Figure 10-79 Control Circuit in Trigger Mode                                              | 323  |
| Figure 10-80 Block Diagram of Advanced-control Timer                                      | 351  |
| Figure 10-81 Counter Timing Diagram with Prescaler Division Changing from 1 to 2          | 353  |
| Figure 10-82 Counter Timing Diagram with Prescaler Division Changing from 1 $\sim$ 4      | 354  |
| Figure 10-83 Counter Timing Diagram with Internal Clock Divided by 1                      | 355  |
| Figure 10-84 Counter Timing Diagram with Internal Clock Divided by 2                      | 355  |
| Figure 10-85 Counter Timing Diagram with Internal Clock Divided by 4                      | 356  |
| Figure 10-86 Counter Timing Diagram with Internal Clock Divided by N                      | 356  |
| Figure 10-87 Counter Timing Diagram with Update Event When ARPEN = 0 (TMRx_AR Not Preload | (bət |
|                                                                                           | 356  |
| Figure 10-88 Counter Timing Diagram with Update Event When ARPEN = 1 (TMRx_AR is Preload  | (bət |
|                                                                                           | 357  |
| Figure 10-89 Counter Timing Diagram with Internal Clock Divided by 1                      | 358  |
| Figure 10-90 Counter Timing Diagram with Internal Clock Divided by 2                      | 358  |
| Figure 10-91 Counter Timing Diagram with Internal Clock Divided by 4                      | 359  |
| Figure 10-92 Counter Timing Diagram with Internal Clock Divided by N                      | 359  |
| Figure 10-93 Counter Timing Diagram of Update Event without Auto-reload                   | 359  |
| Figure 10-94 Counter Timing Diagram with Internal Clock Divided by 1, TMRx_AR = 0x6       | 361  |
| Figure 10-95 Counter Timing Diagram with Internal Clock Divided by 2                      | 361  |
| Figure 10-96 Counter Timing Diagram with Internal Clock Divided by 4, $TMRx_AR = 0x36$    | 361  |
| Figure 10-97 Counter Timing Diagram with Internal Clock Divided by N                      | 362  |
| Figure 10-98 Counter Timing Diagram with Update Event When ARPEN = 1 (Counter underflow)  | 362  |
| Figure 10-99 Counter Timing Diagram with Update Event When ARPEN = 1 (Counter overflow).  | 363  |
| Figure 10-100 Examples of Updating Rates in Different Modes and the TMRx_RC Regi          | ster |
| Configuration                                                                             | 364  |
| Figure 10-101 Control Circuit in Normal Mode with Internal Clock Divided by 1             | 366  |
| Figure 10-102 TI2 External Clock Connection Example                                       | 366  |
| Figure 10-103 Control Circuit in External Clock Mode 1                                    | 367  |
| Figure 10-104 Block Diagram of External Trigger Input                                     | 367  |
| Figure 10-105 Control Circuit in External Clock Mode 2                                    | 368  |
| Figure 10-106 Capture/Compare Channel (e.g. Channel 1 Input Stage)                        | 369  |
| Figure 10-107 Capture/Compare Channel 1 Main Circuit                                      | 369  |
| Figure 10-108 Capture/Compare Channel Output Stage (Channel 1 to 3)                       | 370  |



| Figure 10-109 Capture/Compare Channel Output Stage (Channel 4)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | . 370                                                                                                                                                                                                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Figure 10-110 PWM Input Mode Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . 373                                                                                                                                                                                                                |
| Figure 10-111 Output Compare Mode, Toggle on OC1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | . 375                                                                                                                                                                                                                |
| Figure 10-112 Edge-aligned PWM Waveforms (AR = 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | . 376                                                                                                                                                                                                                |
| Figure 10-113 Center-aligned PWM Waveforms (AR = 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . 377                                                                                                                                                                                                                |
| Figure 10-114 Complementary Output with Dead-time Insertion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | . 379                                                                                                                                                                                                                |
| Figure 10-115 Dead-time Waveform Delay Which is Greater than Negative Pulse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | . 380                                                                                                                                                                                                                |
| Figure 10-116 Dead-time Waveform Delay Which is Greater than Positive Pulse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | . 380                                                                                                                                                                                                                |
| Figure 10-117 Outputs in Response to a Break                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                      |
| Figure 10-118 Clearing OCxREF in TMRx                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | . 384                                                                                                                                                                                                                |
| Figure 10-119 6-step PWM Generation, Example of Using HALL (OSIMR = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | . 385                                                                                                                                                                                                                |
| Figure 10-120 One-pulse Mode Example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | . 386                                                                                                                                                                                                                |
| Figure 10-121 Example of Counter Operation in Encoder Interface Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | . 389                                                                                                                                                                                                                |
| Figure 10-122 Example of Encoder Interface Mode with IC1FP1 Polarity Inverted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | . 389                                                                                                                                                                                                                |
| Figure 10-123 Example of HALL Sensor Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | . 392                                                                                                                                                                                                                |
| Figure 10-124 Control Circuit in Reset Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | . 393                                                                                                                                                                                                                |
| Figure 10-125 Control Circuit in Gated Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | . 394                                                                                                                                                                                                                |
| Figure 10-126 Control Circuit in Trigger Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | . 395                                                                                                                                                                                                                |
| Figure 10-127 Control Circuit in External Clock Mode 2 + Trigger Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | . 396                                                                                                                                                                                                                |
| Figure 11-1 Watchdog Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | . 433                                                                                                                                                                                                                |
| Figure 11-2 Window Watchdog Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | . 435                                                                                                                                                                                                                |
| Figure 11-3 Block Diagram of Independent W atchdog                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | . 440                                                                                                                                                                                                                |
| Figure 12-1 Simplified RTC Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | . 445                                                                                                                                                                                                                |
| Figure 12-2 Example of RTC Second and Alarm Waveform, PR = 0003, ALARM = 00004                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                      |
| Figure 12-3 Example of RTC Overflow Waveform, PR = 0003                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | . 448                                                                                                                                                                                                                |
| $\frac{1}{2} = \frac{1}{2} = \frac{1}$ |                                                                                                                                                                                                                      |
| Figure 12-1 Single ADC Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | . 457                                                                                                                                                                                                                |
| Figure 13-1 Single ADC Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | . 457<br>. 460                                                                                                                                                                                                       |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | . 457<br>. 460<br>. 461                                                                                                                                                                                              |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | . 457<br>. 460<br>. 461<br>. 463                                                                                                                                                                                     |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . 457<br>. 460<br>. 461<br>. 463<br>. 466                                                                                                                                                                            |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 457<br>460<br>461<br>463<br>466<br>466                                                                                                                                                                               |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 457<br>460<br>461<br>463<br>466<br>466<br>466                                                                                                                                                                        |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | . 457<br>. 460<br>. 461<br>. 463<br>. 466<br>. 466<br>. 466<br>. 469                                                                                                                                                 |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | . 457<br>. 460<br>. 461<br>. 463<br>. 466<br>. 466<br>. 466<br>. 469<br>. 488                                                                                                                                        |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | . 457<br>. 460<br>. 461<br>. 463<br>. 466<br>. 466<br>. 466<br>. 469<br>. 488<br>. 488                                                                                                                               |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 457<br>460<br>461<br>463<br>466<br>466<br>466<br>466<br>469<br>488<br>488<br>488                                                                                                                                     |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | . 457<br>. 460<br>. 461<br>. 463<br>. 466<br>. 466<br>. 466<br>. 469<br>. 488<br>. 488<br>. 488<br>. 491<br>. 491                                                                                                    |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram.<br>Figure 13-3 Analog Watchdog Guarded Area.<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter<br>Figure 14-4 Transfer Sequence Diagram of Slave Receiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 457<br>460<br>461<br>463<br>466<br>466<br>466<br>466<br>469<br>488<br>488<br>488<br>491<br>491                                                                                                                       |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter<br>Figure 14-4 Transfer Sequence Diagram of Master Transmitter<br>Figure 14-6 Transfer Sequence Diagram of Master Receiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | . 457<br>. 460<br>. 461<br>. 463<br>. 466<br>. 466<br>. 466<br>. 469<br>. 488<br>. 488<br>. 488<br>. 491<br>. 491<br>. 495<br>. 496                                                                                  |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram.<br>Figure 13-3 Analog Watchdog Guarded Area.<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT.<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter<br>Figure 14-5 Transfer Sequence Diagram of Master Transmitter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 457<br>460<br>461<br>463<br>466<br>466<br>466<br>466<br>469<br>488<br>488<br>491<br>491<br>495<br>495<br>496<br>497                                                                                                  |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter<br>Figure 14-4 Transfer Sequence Diagram of Master Transmitter<br>Figure 14-6 Transfer Sequence Diagram for Master Receiver<br>Figure 14-7 Transfer Sequence Diagram for Master Receiver when N > 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | . 457<br>. 460<br>. 461<br>. 463<br>. 466<br>. 466<br>. 466<br>. 469<br>. 488<br>. 488<br>. 488<br>. 491<br>. 491<br>. 495<br>. 496<br>. 497<br>. 498                                                                |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter<br>Figure 14-4 Transfer Sequence Diagram of Master Transmitter<br>Figure 14-5 Transfer Sequence Diagram of Master Receiver<br>Figure 14-7 Transfer Sequence Diagram for Master Receiver when N > 2<br>Figure 14-8 Transfer Sequence Diagram for Master Receiver when N > 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 457<br>460<br>461<br>463<br>466<br>466<br>466<br>466<br>469<br>488<br>488<br>491<br>491<br>495<br>495<br>495<br>495<br>495                                                                                           |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter<br>Figure 14-4 Transfer Sequence Diagram of Master Transmitter<br>Figure 14-5 Transfer Sequence Diagram of Master Receiver<br>Figure 14-6 Transfer Sequence Diagram for Master Receiver when N > 2<br>Figure 14-8 Transfer Sequence Diagram for Master Receiver when N > 2<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 2<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 457<br>460<br>461<br>463<br>466<br>466<br>466<br>469<br>488<br>488<br>488<br>488<br>491<br>491<br>495<br>495<br>495<br>495<br>495<br>495                                                                             |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter<br>Figure 14-4 Transfer Sequence Diagram of Master Transmitter<br>Figure 14-5 Transfer Sequence Diagram of Master Receiver<br>Figure 14-7 Transfer Sequence Diagram for Master Receiver when N > 2<br>Figure 14-8 Transfer Sequence Diagram for Master Receiver when N = 2<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 1<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 1<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 1<br>Figure 14-10 I <sup>2</sup> C Interrupt Mapping Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 457<br>460<br>461<br>463<br>466<br>466<br>466<br>466<br>469<br>488<br>488<br>491<br>491<br>495<br>495<br>495<br>495<br>495<br>495<br>495<br>495<br>495<br>495                                                        |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter<br>Figure 14-4 Transfer Sequence Diagram of Master Transmitter<br>Figure 14-5 Transfer Sequence Diagram of Master Receiver<br>Figure 14-6 Transfer Sequence Diagram for Master Receiver when N > 2<br>Figure 14-8 Transfer Sequence Diagram for Master Receiver when N = 2<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 2<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 2<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 2<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 2<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 1<br>Figure 14-10 I <sup>2</sup> C Interrupt Mapping Diagram<br>Figure 15-1 USART Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | . 457<br>. 460<br>. 461<br>. 463<br>. 466<br>. 466<br>. 469<br>. 488<br>. 488<br>. 488<br>. 491<br>. 491<br>. 491<br>. 495<br>. 496<br>. 497<br>. 498<br>. 498<br>. 508<br>. 529<br>. 530                            |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area.<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter<br>Figure 14-4 Transfer Sequence Diagram of Master Transmitter<br>Figure 14-5 Transfer Sequence Diagram of Master Receiver<br>Figure 14-6 Transfer Sequence Diagram for Master Receiver when N > 2<br>Figure 14-7 Transfer Sequence Diagram for Master Receiver when N > 2<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 1<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 1<br>Figure 14-10 I <sup>2</sup> C Interrupt Mapping Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 457<br>460<br>461<br>463<br>466<br>466<br>466<br>466<br>488<br>488<br>488<br>491<br>491<br>495<br>495<br>495<br>495<br>495<br>495<br>495<br>495<br>508<br>508<br>529<br>530                                          |
| Figure 13-1 Single ADC Block Diagram<br>Figure 13-2 Timing Diagram<br>Figure 13-3 Analog Watchdog Guarded Area.<br>Figure 13-4 Injected Conversion Latency<br>Figure 13-5 Calibration Timing Diagram<br>Figure 13-6 Right-alignment of Data<br>Figure 13-7 Left-alignment of Data<br>Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT<br>Figure 14-1 I <sup>2</sup> C Bus Protocol<br>Figure 14-2 Block Diagram of I <sup>2</sup> C Function<br>Figure 14-3 Transfer Sequence Diagram of Slave Transmitter<br>Figure 14-4 Transfer Sequence Diagram of Master Transmitter<br>Figure 14-5 Transfer Sequence Diagram of Master Receiver<br>Figure 14-7 Transfer Sequence Diagram for Master Receiver when N > 2<br>Figure 14-8 Transfer Sequence Diagram for Master Receiver when N > 2<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 1<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 1<br>Figure 14-9 Transfer Sequence Diagram for Master Receiver when N = 1<br>Figure 14-10 I <sup>2</sup> C Interrupt Mapping Diagram<br>Figure 15-1 USART Block Diagram<br>Figure 15-3 Stop Bits Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | . 457<br>. 460<br>. 461<br>. 463<br>. 466<br>. 466<br>. 469<br>. 488<br>. 488<br>. 488<br>. 488<br>. 491<br>. 491<br>. 491<br>. 495<br>. 496<br>. 497<br>. 498<br>. 498<br>. 508<br>. 529<br>. 530<br>. 532<br>. 534 |



| Figure 15-7 Mute Mode Using Idle Line Detection 545                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| Figure 15-8 Mute Mode Using Address Mark Detection 545                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 5                                                                                                |
| Figure 15-9 Break Detection in LIN Mode (11-bit break length - The LBDLEN bit is set) 548                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 3                                                                                                |
| Figure 15-10 Break Detection and Framing Error Detection in LIN Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 3                                                                                                |
| Figure 15-11 Example of USART Synchronous Transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | )                                                                                                |
| Figure 15-12 Example of USART Data Clock Timing (LEN = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | )                                                                                                |
| Figure 15-13 Example of USART Data Clock Timing (LEN = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | L                                                                                                |
| Figure 15-14 Rx Data Setup/Hold Time 551                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | L                                                                                                |
| Figure 15-15 ISO7816-3 Asynchronous Protocol 553                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 3                                                                                                |
| Figure 15-16 Parity Error Detection Using 1.5 stop bits 554                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                  |
| Figure 15-17 IrDA SIR ENDEC Block Diagram 557                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 7                                                                                                |
| Figure 15-18 IrDA Data Modulation( 3/16) - Normal Mode 557                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                  |
| Figure 15-19 Transmission Using DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                  |
| Figure 15-20 Reception Using DMA 559                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Э                                                                                                |
| Figure 15-21 Hardware Flow Control between Two USART                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                  |
| Figure 15-22 RTS Flow Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                  |
| Figure 15-23 CTS Flow Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                  |
| Figure 15-24 USART Interrupt Mapping Diagram 562                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                  |
| Figure 16-1 SPI Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                  |
| Figure 16-2 Single Master and Single Slave Application                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                  |
| Figure 16-3 Hardware/Software Slave Select Management                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                  |
| Figure 16-4 Data Clock Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                  |
| Figure 16-5 TE/RNE/BSY Behavior during Continuous Output in Master/Full-duplex Mode (BDMODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                  |
| = 0 and RONLY = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                  |
| Figure 16-6 TE/RNE/BSY Behavior during Continuous Transfer in Slave/Full-duplex Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                  |
| (BDMODE = 0 and RONLY = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                  |
| Figure 16-7 TE/BSY Behavior during Continuous Transfer in Master Transmit-only Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                  |
| (BDMODE = 0 and RONLY = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                  |
| Figure 16-8 TE/BSY Behavior during Continuous Transfer in Slave Transmit-only Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                  |
| (BDMODE = 0  and  RONLY = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3                                                                                                |
| Figure 16-9 RNE Behavior during Continuous Transfer in Receive-only Mode (BDMODE = 0 and RONL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                  |
| = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                  |
| Figure 16-10 TE/BSY Behavior during Discontinuous Transfer (BDMODE = 0 and RONLY = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -                                                                                                |
| Figure 16-11 Transmission using DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | )                                                                                                |
| Figure 16-12 Reception using DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                  |
| Figure 16-12 Reception using DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | )                                                                                                |
| Figure 16-13 I <sup>2</sup> S Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | )<br>3                                                                                           |
| Figure 16-13 I <sup>2</sup> S Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | )<br>3<br>5                                                                                      |
| Figure 16-13 I2S Block Diagram603Figure 16-14 I2S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)605Figure 16-15 I2S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)606                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 5                                                                                                |
| Figure 16-13 I2S Block Diagram603Figure 16-14 I2S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)605Figure 16-15 I2S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)606Figure 16-16 Transmitting 0x8EAA33606                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 555                                                                                              |
| Figure 16-13 I2S Block Diagram603Figure 16-14 I2S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)605Figure 16-15 I2S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)606Figure 16-16 Transmitting 0x8EAA33606Figure 16-17 Receiving 0x8EAA33606                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                  |
| Figure 16-13 I2S Block Diagram603Figure 16-14 I2S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)605Figure 16-15 I2S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)606Figure 16-16 Transmitting 0x8EAA33606Figure 16-17 Receiving 0x8EAA33606Figure 16-18 I2S Philips Protocol Standard Waveforms (16-bit extended to 32-bit frame, CPOL = 0)                                                                                                                                                                                                                                                                                                                | )<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 |
| Figure 16-13 I2S Block Diagram603Figure 16-14 I2S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)605Figure 16-15 I2S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)606Figure 16-16 Transmitting 0x8EAA33606Figure 16-17 Receiving 0x8EAA33606Figure 16-18 I2S Philips Protocol Standard Waveforms (16-bit extended to 32-bit frame, CPOL = 0)606606606                                                                                                                                                                                                                                                                                                       | 0<br>3<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 |
| Figure 16-13 I2S Block Diagram603Figure 16-14 I2S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)605Figure 16-15 I2S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)606Figure 16-16 Transmitting 0x8EAA33606Figure 16-17 Receiving 0x8EAA33606Figure 16-18 I2S Philips Protocol Standard Waveforms (16-bit extended to 32-bit frame, CPOL = 0)606Figure 16-19 Example607                                                                                                                                                                                                                                                                                      | 0 3 5 5 5 5 ) 5 7                                                                                |
| Figure 16-13 I²S Block Diagram603Figure 16-14 I²S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)605Figure 16-15 I²S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)606Figure 16-16 Transmitting 0x8EAA33606Figure 16-17 Receiving 0x8EAA33606Figure 16-18 I²S Philips Protocol Standard Waveforms (16-bit extended to 32-bit frame, CPOL = 0)606Figure 16-19 Example607Figure 16-20 MSB-justified 16-bit or 32-bit Full-accuracy, CPOL = 0607                                                                                                                                                                                                                | 035555)577                                                                                       |
| Figure 16-13 I²S Block Diagram603Figure 16-14 I²S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)605Figure 16-15 I²S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)606Figure 16-16 Transmitting 0x8EAA33606Figure 16-17 Receiving 0x8EAA33606Figure 16-18 I²S Philips Protocol Standard Waveforms (16-bit extended to 32-bit frame, CPOL = 0)606Figure 16-19 Example607Figure 16-20 MSB-justified 16-bit or 32-bit Full-accuracy, CPOL = 0.607Figure 16-21 MSB-justified 24-bit Data, CPOL = 0.608                                                                                                                                                           | 035555)5773                                                                                      |
| Figure 16-13 I²S Block Diagram603Figure 16-14 I²S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)605Figure 16-15 I²S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)606Figure 16-16 Transmitting 0x8EAA33606Figure 16-17 Receiving 0x8EAA33606Figure 16-18 I²S Philips Protocol Standard Waveforms (16-bit extended to 32-bit frame, CPOL = 0)606Figure 16-19 Example607Figure 16-20 MSB-justified 16-bit or 32-bit Full-accuracy, CPOL = 0.607Figure 16-21 MSB-justified 24-bit Data, CPOL = 0.607Figure 16-22 MSB-justified 16-bit Data Extended to 32-bit Frame, CPOL = 0.608Figure 16-22 MSB-justified 16-bit Data Extended to 32-bit Frame, CPOL = 0.608 | 035555)57733                                                                                     |
| Figure 16-13 I²S Block Diagram603Figure 16-14 I²S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)605Figure 16-15 I²S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)606Figure 16-16 Transmitting 0x8EAA33606Figure 16-17 Receiving 0x8EAA33606Figure 16-18 I²S Philips Protocol Standard Waveforms (16-bit extended to 32-bit frame, CPOL = 0)606Figure 16-19 Example607Figure 16-20 MSB-justified 16-bit or 32-bit Full-accuracy, CPOL = 0.607Figure 16-21 MSB-justified 24-bit Data, CPOL = 0.608                                                                                                                                                           | 035555)577333                                                                                    |



| Figure 16-25 Operations Required to Transmit 0x3478AE                                         | 609  |
|-----------------------------------------------------------------------------------------------|------|
| Figure 16-26 Operations Required to Receive 0x3478AE                                          | 609  |
| Figure 16-27 LSB-justified 16-bit Data Extended to 32-bit Frame, CPOL = 0                     | 609  |
| Figure 16-28 Example                                                                          | 610  |
| Figure 16-29 PCM Standard Waveform (16-bit)                                                   | 610  |
| Figure 16-30 PCM Standard Waveform (16-bit extended to 32-bit package frame)                  | 611  |
| Figure 16-31 Definition of Audio Sampling Frequency                                           | 611  |
| Figure 16-32 I <sup>2</sup> S Clock Generator Architecture                                    | 612  |
| Figure 17-1 CAN Network Topology                                                              | 635  |
| Figure 17-2 CAN Block Diagram                                                                 | 636  |
| Figure 17-3 bxCAN Operating Mode                                                              | 639  |
| Figure 17-4 bxCAN in Silent Mode                                                              | 640  |
| Figure 17-5 bxCAN in Loopback Mode                                                            | 640  |
| Figure 17-6 bxCAN in Loopback and Silent Mode                                                 | 641  |
| Figure 17-7 Transmit Mailbox States                                                           | 643  |
| Figure 17-8 Receive FIFO States                                                               | 644  |
| Figure 17-9 Filter Bank Scale Configuration - Register Organization                           | 647  |
| Figure 17-10 Example of Filter Numbering                                                      | 649  |
| Figure 17-11 Example of Filtering Mechanism                                                   | 650  |
| Figure 17-12 CAN Error State Diagram                                                          | 651  |
| Figure 17-13 Bit Timing                                                                       |      |
| Figure 17-14 Various CAN Frames                                                               |      |
| Figure 17-15 Event Flag and Interrupt Generation                                              |      |
| Figure 17-16 Tx and Rx Mailboxes                                                              |      |
| Figure 18-1 XMC Block Diagram                                                                 |      |
| Figure 18-2 XMC Memory Banks                                                                  |      |
| Figure 18-3 Mode 1 Read Access                                                                |      |
| Figure 18-4 Mode 1 Write Access                                                               |      |
| Figure 18-5 Mode A Read Access                                                                |      |
| Figure 18-6 Mode A Write Access                                                               |      |
| Figure 18-7 Mode 2/B Read Access                                                              |      |
| Figure 18-8 Mode 2 Write Access                                                               |      |
| Figure 18-9 Mode B Write Access                                                               |      |
| Figure 18-10 Mode C Read Access                                                               |      |
| Figure 18-11 Mode C Write Access                                                              |      |
| Figure 18-12 Mode D Read Access                                                               |      |
| Figure 18-13 Mode D Write Access                                                              |      |
| Figure 18-14 Multiplexed Read Access                                                          |      |
| Figure 18-15 Multiplexed Write Access                                                         |      |
| Figure 18-16 Synchronous Multiplexed Read Mode- NOR and PSRAM (CRAM)                          |      |
| Figure 18-17 Synchronous Multiplexed Write Mode- PSRAM (CRAM)                                 |      |
| Figure 18-18 NAND Controller Timing for Common Memory Access                                  |      |
| Figure 18-19 Access to Non "CE Don't Care" NAND Flash                                         |      |
| Figure 19-1 USB Peripheral Block Diagram                                                      |      |
| Figure 19-2 Packet Buffer Areas and Associated Buffer Description Table Locations             |      |
| Figure 20-1 Block Diagram of V84XXX-Level and Cortex $^{\mathbb{R}}$ -M4F-Level Debug Support |      |
| right 20 I block blagrant of votAAA-Level and Cortex ~ -1941 -Level bebug Support             | ,,,, |



## Table

| Table 1-1 Register Boundary Address                                               |     |
|-----------------------------------------------------------------------------------|-----|
| Table 1-2 Flash Memory Module Organization (V8411N)                               |     |
| Table 1-3 Flash Memory Module Organization (V8410N and V8411S)                    | 35  |
| Table 1-4 Flash Memory Module Organization (V8410C)                               |     |
| Table 1-5 Boot Mode                                                               |     |
| Table 1-6 List of for Register Abbreviations                                      | 39  |
| Table 2-1 SLP-NOW Mode                                                            |     |
| Table 2-2 SLP-ON-EXIT Mode                                                        |     |
| Table 2-3 Stop Mode                                                               |     |
| Table 2-4 Standby Mode                                                            |     |
| Table 5-1 Flash Memory Architecture(V8411N)                                       | 105 |
| Table 5-2 Flash Memory Architecture(V8410N and V8411S)                            | 106 |
| Table 5-3 Flash Memory Architecture(V8410C)                                       | 108 |
| Table 5-4 Flash Memory Protection Status                                          | 120 |
| Table 5-5 Option Byte Format                                                      | 121 |
| Table 5-6 Information Block Organization                                          | 121 |
| Table 5-7 User Option Byte Description                                            | 122 |
| Table 7-1 Port Bit Assignment                                                     | 144 |
| Table 7-2 Output MODE                                                             | 145 |
| Table 7-3 Advanced Timers TMR1/8                                                  | 150 |
| Table 7-4 General-purpose Timer TMR2-5/TMR9-14                                    | 150 |
| Table 7-5 USART                                                                   | 151 |
| Table 7-6 SPI                                                                     | 151 |
| Table 7-7 I <sup>2</sup> S                                                        | 152 |
| Table 7-8 I <sup>2</sup> C Interface                                              | 152 |
| Table 7-9 BxCAN                                                                   | 152 |
| Table 7-10 USB                                                                    | 152 |
| Table 7-11 ADC                                                                    | 153 |
| Table 7-12 XMC                                                                    | 153 |
| Table 7-13 Other I/O Functions                                                    | 153 |
| Table 7-14 CA1 Alternate Function Remapping                                       | 154 |
| Table 7-15 Debug Interface Signal                                                 | 154 |
| Table 7-16 Debug Port Mapping                                                     | 155 |
| Table 7-17 ADC1 External Trigger Injected Conversion Alternate Function Remapping | 156 |
| Table 7-18 ADC1 External Trigger Regular Conversion Alternate Function Remapping  | 156 |
| Table 7-19 TMR1 Alternate Function Remapping                                      | 156 |
| Table 7-20 TMR2 Alternate Function Remapping                                      | 157 |
| Table 7-21 TMR3 Alternate Function Remapping                                      | 157 |
| Table 7-22 TMR4 Alternate Function Remapping                                      | 157 |
| Table 7-23 TMR5 Alternate Function Remapping                                      | 158 |
| Table 7-24 TMR9 Alternate Function Remapping                                      | 158 |
| Table 7-25 USART1 Remapping                                                       | 158 |
| Table 7-26 USART2 Remapping                                                       | 158 |
| Table 7-27 USART3 Remapping                                                       | 159 |
| Table 7-28 UART 4 Remapping                                                       | 159 |
| Table 7-29 UART 5 Remapping                                                       | 159 |



| Table 7-30 USART 6 Remapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 159                                                                                                                                             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Table 7-31 UART 7 Remapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 159                                                                                                                                             |
| Table 7-32 UART 8 Remapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                 |
| Table 7-33 I2C1 Remapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 160                                                                                                                                             |
| Table 7-34 I2C3 Remapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                 |
| Table 7-35 SPI1/I2S1 Remapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                 |
| Table 7-36 SPI2/I2S2 Remapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                 |
| Table 7-37 SPI3/I2S3 Remapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                 |
| Table 7-38 SPI4/I2S4 Remapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                 |
| Table 7-39 XMC Alternate Function Remapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                 |
| Table 8-1 Vector Table of V84XXX Series                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                 |
| Table 9-1 Programmable Data Transfer Width and Endian Behavior (When PINC = MINC = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                 |
| Table 9-2 DMA Interrupt Request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                 |
| Table 9-3 Summary of DMA1 Requests for Each Channel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                 |
| Table 9-4 Summary of DMA2 Requests for Each Channel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                 |
| Table 9-5 DMA Flexible Request of each Channel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                 |
| Table 10-1 Counting Direction and Encoder Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                 |
| Table 10-2 TMRx Internal Trigger Connection (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 282                                                                                                                                             |
| Table 10-3 Standard OCx Channel Output Control Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                 |
| Table 10-4 TMRx Internal Trigger Connection(Note)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                 |
| Table 10-5 Standard OCx Channel Output Control Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                 |
| Table 10-6 Standard OCx Channel Output Control Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 348                                                                                                                                             |
| Table 10-7 Counting Direction and Encoder Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 388                                                                                                                                             |
| Table 10-8 TMRx Internal Trigger Connection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 405                                                                                                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                 |
| Table 10-9 Complementary Output Channel OCx and OCxN Control Bits with Break Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 421                                                                                                                                             |
| Table 10-9 Complementary Output Channel OCx and OCxN Control Bits with Break Function<br>Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) (Note)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 440                                                                                                                                             |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 440<br>457                                                                                                                                      |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 440<br>457<br>462                                                                                                                               |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC PinsTable 13-2 Analog Watchdog Channel Selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 440<br>457<br>462<br>467                                                                                                                        |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC PinsTable 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular Channels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 440<br>457<br>462<br>467<br>468                                                                                                                 |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC PinsTable 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected Channels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 440<br>457<br>462<br>467<br>468<br>471                                                                                                          |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC PinsTable 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 440<br>457<br>462<br>467<br>468<br>471<br>502                                                                                                   |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC PinsTable 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC InterruptsTable 14-1 Comparison between SMBus and I <sup>2</sup> C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507                                                                                            |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) (Note)<br>Table 13-1 ADC Pins<br>Table 13-2 Analog Watchdog Channel Selection<br>Table 13-3 ADC1 Used in External Trigger for Regular Channels<br>Table 13-4 ADC1 Used in External Trigger for Injected Channels<br>Table 13-5 ADC Interrupts<br>Table 14-1 Comparison between SMBus and I <sup>2</sup> C<br>Table 14-2 I <sup>2</sup> C Interrupt Request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507                                                                                            |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC Pins.Table 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC InterruptsTable 14-1 Comparison between SMBus and I²CTable 14-2 I²C Interrupt RequestTable 15-1 Sampled Data from Noise DetectionTable 15-2 Error Calculation for Programming Baud RatesTable 15-3 USART Receiver Tolerance When DIV_Decimal = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507<br>539<br>542                                                                              |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) (Note)<br>Table 13-1 ADC Pins<br>Table 13-2 Analog Watchdog Channel Selection<br>Table 13-3 ADC1 Used in External Trigger for Regular Channels<br>Table 13-4 ADC1 Used in External Trigger for Injected Channels<br>Table 13-5 ADC Interrupts<br>Table 14-1 Comparison between SMBus and I <sup>2</sup> C<br>Table 14-2 I <sup>2</sup> C Interrupt Request<br>Table 15-1 Sampled Data from Noise Detection<br>Table 15-2 Error Calculation for Programming Baud Rates                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507<br>539<br>542                                                                              |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC Pins.Table 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC InterruptsTable 14-1 Comparison between SMBus and I²CTable 14-2 I²C Interrupt RequestTable 15-1 Sampled Data from Noise DetectionTable 15-2 Error Calculation for Programming Baud RatesTable 15-3 USART Receiver Tolerance When DIV_Decimal = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507<br>539<br>542<br>543<br>544                                                                |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC Pins.Table 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC InterruptsTable 14-1 Comparison between SMBus and I²CTable 14-2 I²C Interrupt RequestTable 15-1 Sampled Data from Noise DetectionTable 15-2 Error Calculation for Programming Baud RatesTable 15-4 USART Receiver Tolerance When DIV_Decimal = 0Table 15-5 Frame FormatTable 15-6 USART Interrupt Request                                                                                                                                                                                                                                                                                                                                                                                                      | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507<br>539<br>542<br>543<br>544<br>546<br>562                                                  |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC Pins.Table 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC InterruptsTable 14-1 Comparison between SMBus and I²CTable 14-2 I²C Interrupt RequestTable 15-1 Sampled Data from Noise DetectionTable 15-2 Error Calculation for Programming Baud RatesTable 15-3 USART Receiver Tolerance When DIV_Decimal = 0Table 15-5 Frame Format.                                                                                                                                                                                                                                                                                                                                                                                                                                       | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507<br>539<br>542<br>543<br>544<br>546<br>562                                                  |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC Pins.Table 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC InterruptsTable 14-1 Comparison between SMBus and I²CTable 14-2 I²C Interrupt RequestTable 15-1 Sampled Data from Noise DetectionTable 15-2 Error Calculation for Programming Baud RatesTable 15-4 USART Receiver Tolerance When DIV_Decimal = 0Table 15-5 Frame FormatTable 15-6 USART Interrupt Request                                                                                                                                                                                                                                                                                                                                                                                                      | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507<br>539<br>542<br>543<br>544<br>546<br>546<br>562                                           |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC PinsTable 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC InterruptsTable 14-1 Comparison between SMBus and I²CTable 14-2 I²C Interrupt RequestTable 15-1 Sampled Data from Noise DetectionTable 15-2 Error Calculation for Programming Baud RatesTable 15-3 USART Receiver Tolerance When DIV_Decimal = 0Table 15-5 Frame FormatTable 15-6 USART Interrupt RequestTable 15-7 USART Mode Configuration ( Note )                                                                                                                                                                                                                                                                                                                                                           | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507<br>539<br>542<br>543<br>544<br>544<br>546<br>562<br>563<br>602                             |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507<br>539<br>542<br>543<br>544<br>546<br>562<br>563<br>602<br>612                             |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC PinsTable 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC InterruptsTable 14-1 Comparison between SMBus and I²CTable 14-2 I²C Interrupt RequestTable 15-1 Sampled Data from Noise DetectionTable 15-2 Error Calculation for Programming Baud RatesTable 15-4 USART Receiver Tolerance When DIV_Decimal = 0Table 15-5 Frame FormatTable 15-6 USART Interrupt RequestTable 15-7 USART Mode Configuration ( Note )Table 16-1 SPI Interrupt RequestTable 16-2 Audio-frequency Precision Using System Clock                                                                                                                                                                                                                                                                    | 440<br>457<br>462<br>467<br>502<br>507<br>539<br>542<br>543<br>544<br>544<br>546<br>542<br>562<br>563<br>602<br>612                             |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 440<br>457<br>462<br>467<br>502<br>507<br>539<br>542<br>543<br>544<br>546<br>562<br>563<br>602<br>612<br>620<br>651                             |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC Pins.Table 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC InterruptsTable 14-1 Comparison between SMBus and I <sup>2</sup> CTable 14-2 I <sup>2</sup> C Interrupt RequestTable 15-1 Sampled Data from Noise DetectionTable 15-2 Error Calculation for Programming Baud RatesTable 15-3 USART Receiver Tolerance When DIV_Decimal = 0Table 15-5 Frame FormatTable 15-6 USART Interrupt RequestTable 15-7 USART Mode Configuration ( Note )Table 16-1 SPI Interrupt RequestTable 16-1 SPI Interrupt RequestTable 16-1 SPI Interrupt RequestTable 16-2 Audio-frequency Precision Using System ClockTable 16-3 I <sup>2</sup> S Interrupt RequestTable 16-3 I <sup>2</sup> S Interrupt Request                                                                               | 440<br>457<br>462<br>467<br>502<br>507<br>539<br>542<br>543<br>543<br>544<br>546<br>562<br>563<br>602<br>612<br>620<br>651                      |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)Table 13-1 ADC PinsTable 13-2 Analog Watchdog Channel SelectionTable 13-3 ADC1 Used in External Trigger for Regular ChannelsTable 13-4 ADC1 Used in External Trigger for Injected ChannelsTable 13-5 ADC InterruptsTable 14-1 Comparison between SMBus and I²CTable 14-2 I²C Interrupt RequestTable 15-1 Sampled Data from Noise DetectionTable 15-2 Error Calculation for Programming Baud RatesTable 15-3 USART Receiver Tolerance When DIV_Decimal = 0Table 15-5 Frame FormatTable 15-7 USART Mode Configuration ( Note )Table 16-1 SPI Interrupt RequestTable 16-2 Audio-frequency Precision Using System ClockTable 16-3 I²S Interrupt RequestTable 17-1 Transmit Mailbox MappingTable 17-2 Receive Mailbox Mapping | 440<br>457<br>462<br>467<br>468<br>471<br>502<br>507<br>539<br>542<br>543<br>544<br>546<br>562<br>563<br>602<br>612<br>620<br>651<br>651        |
| Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) ( Note)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 440<br>457<br>462<br>467<br>502<br>507<br>539<br>542<br>543<br>544<br>546<br>562<br>563<br>602<br>612<br>620<br>651<br>651<br>686<br>686<br>686 |

| Table 18-5 Programmable NOR/PSRAM Access Parameters                | 689 |
|--------------------------------------------------------------------|-----|
| Table 18-6 Non-multiplexed I/Os of NOR Flash Interface             | 690 |
| Table 18-7 Multiplexed I/Os of NOR Flash Interface                 |     |
| Table 18-8 Non-multiplexed I/Os of PSRAM Interface                 |     |
| Table 18-9 Supported NOR Flash/PSRAM Memory and Transaction of XMC | 691 |
| Table 18-10 XMC_BK1CTRLx Bit Field (Mode 1)                        |     |
| Table 18-11 XMC_BK1TMGx Bit Field (Mode 1)                         | 695 |
| Table 18-12 XMC_BK1CTRLx Bit Field (Mode A)                        | 696 |
| Table 18-13 XMC_BK1TMGx Bit Field (Mode A)                         |     |
| Table 18-14 XMC_BK1TMGWRx Bit Field (Mode A)                       |     |
| Table 18-15 XMC_BK1CTRLx Bit Field (Mode 2/B)                      | 700 |
| Table 18-16 XMC_BK1TMGx Bit Field (Mode 2/B)                       | 700 |
| Table 18-17 XMC_BK1TMGWRx Bit Field (Mode 2/B)                     |     |
| Table 18-18 XMC_BK1CTRLx Bit Field (Mode C)                        |     |
| Table 18-19 XMC_BK1TMGx Bit Field (Mode C)                         |     |
| Table 18-20 XMC_BK1TMGWRx Bit Field (Mode C)                       |     |
| Table 18-21 XMC_BK1CTRLx Bit Field (Mode D)                        | 705 |
| Table 18-22 XMC_BK1TMGx Bit Field (Mode D)                         |     |
| Table 18-23 XMC_BK1TMGWRx Bit Field (Mode D)                       | 705 |
| Table 18-24 XMC_BK1CTRLx Bit Field (Multiplexed Mode)              |     |
| Table 18-25 XMC_BK1TMGx Bit Field (Multiplexed Mode)               | 708 |
| Table 18-26 XMC_BK1CTRLx Bit Field (Synchronous Mode)              | 710 |
| Table 18-27 XMC_BK1TMGx Bit Field (Synchronous Mode)               |     |
| Table 18-28 XMC_BK1CTRLx Bit Field (Synchronous Mode)              | 712 |
| Table 18-29 XMC_BK1TMGx Bit Field (Synchronous Mode)               | 713 |
| Table 18-30 Programmable NAND Access Parameter                     | 713 |
| Table 18-31 8-bit NAND Flash                                       | 714 |
| Table 18-32 16-bit NAND Flash                                      | 714 |
| Table 18-33 Supported Memories and Transactions                    | 715 |
| Table 18-34 XMC Registers Address Mapping                          | 719 |
| Table 18-35 ECC Result Relevant Bit                                | 737 |
| Table 19-1 Packet Buffer Area Configuration                        | 747 |
| Table 19-2 Double-buffering Bulk Endpoint - Buffer Flag Definition | 751 |
| Table 19-3 Double-buffered Bulk Endpoint Flags                     | 752 |
| Table 19-4 Isochronous Memory Buffers Flags                        | 753 |
| Table 19-5 Resume Event Detection                                  | 755 |
| Table 19-6 Reception Status Encoding                               | 771 |
| Table 19-7 Endpoint Type Encoding                                  | 771 |
| Table 19-8 Endpoint Kind Meaning                                   | 771 |
| Table 19-9 Definition of Allocated Buffer Memory                   | 774 |
|                                                                    |     |



## **Revision History**

| Revision | Date        | Description                                                                                                                                   |
|----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 1.0      | Sep.23,2020 | Initial Version                                                                                                                               |
| 1.1      | Jan.11,2021 | Delete TRACESWO function                                                                                                                      |
| 1.2      | Jul.23,2021 | V8411S support 3 SPI: SPI1, SPI2 and SPI4.                                                                                                    |
| 1.3      | Aug.30,2021 | V8411S supports 4 USART and 3 UART;<br>Modify the pin description and package information for V8411S;                                         |
| 1.4      | Sep.9,2021  | Update LQFP100 package information                                                                                                            |
| 1.5      | Dec.29,2021 | Delete TRACESWO function                                                                                                                      |
| 1.6      | Jan.4,2022  | Supplementary description: The 3-way SPI interface of V8411S is SPI1, SPI2, SPI4, without SPI3                                                |
| 1.7      | Mar.1,2022  | V8411S supports 2 USARTs and 3 UARTs;<br>Modify V8411S pin definition diagram and package diagram;<br>Supplement V8411S 35/36 pin description |
| 1.8      | Jul.13,2022 | Update LQFP100 encapsulation data                                                                                                             |
| 1.9      | Oct.21,2022 | Increase Bit 6 description of USART_CTRL1                                                                                                     |



## **1 System Architecture**

V84XXX series microcontrollers consist of ARM<sup>®</sup> Cortex<sup>®</sup>-M4F processor core, bus architecture, peripherals, and memory. Cortex<sup>®</sup>-M4F process is a stage-of-the-art core, featuring many advanced functions. Compared with Cortex<sup>®</sup>-M3, Cortex<sup>®</sup>-M4F processer supports strengthened high-performance DSP instruction set, including extended single cycle 16-bit/32-bit multiply accumulate (MAC), dual 16-bit MAC instruction, optimized 8-bit/16-bit SIMD operation and saturation operation instruction, and single-precision (IEEE-754) float point unit (FPU). When Cortex<sup>®</sup>-M4F is designed with DSP function, it can save power and is faster than software solution. Cortex<sup>®</sup>-M4F will be applicable for those products and markets that require high performance and low power consumption.

## **1.1 System Introduction**

V84XXX main system is based on AHB bus matrix integration. AHB bus matrix is based on AMBA3.0 AHB-LITE multilayer AHB, enabling parallel access paths between masters and slaves in the system, ensuring the effectiveness of bus bandwidth. AHB bus matrix includes five masters: Cortex<sup>®</sup>- M4F core I-Code bus, D-Code bus, system bus, and two DMA controllers. Bus includes six slaves: Flash Memory Controller (FMC), on-chip SRAM, External memory controller (XMC), controller, and two APB bus bridges. System bus is used for loading/ storing data and debug access of the system memory areas. System memory areas include on-chip SRAM area, external memory area, and peripheral map area.

System AHB bus is connected to all AHB peripherals; in addition, two AHB-APB bridges are included for full synchronous connection between system AHB bus and two APB buses. Two APB buses are connected to all APB peripherals. APB1/APB2 buses are limited to the maximum value of 90 MHz. The above-mentioned devices are interconnected through multilayer AHB bus architecture, as shown in Figure 1-1.

Figure 1-1 V84XXX Series Microcontrollers System Architecture





## **1.1.1 Bus Architecture**

### I-Code bus

This bus connects the Instruction bus of the  $Cortex^{(R)}$ -M4F core to the Flash memory instruction



interface. Prefetching is performed on this bus.

#### • D-Code bus

This bus connects the D-Code bus (literal load and debug access) of the Cortex®- M4F core to the Flash memory data interface.

#### • System bus

This bus connects the system bus of the Cortex®-M4F (peripherals bus) to a BusMatrix which manages the arbitration between the core and the DMA.

#### • DMA bus

This bus connects the AHB master interface of the DMA to the BusMatrix which manages the access of CPU D-Code and DMA to SRAM, Flash memory, and peripherals.

### • Bus Matrix

The BusMatrix manages the access arbitration between the core system bus and the DMA master bus. The arbitration uses a Round Robin algorithm. AHB peripherals are connected on system bus through a BusMatrix to allow DMA access.

### • AHB/APB Bridge (APB)

The two AHB/APB bridges provide full synchronous connections between the AHB and the 2 APB buses. APB1 and APB2 are limited to 100 MHz. Please refer to Section 1.2 for the address mapping of the peripherals connected to each bridge. After each device reset, all peripheral clocks, except for the SRAM and FMC, are disabled. Before using a peripheral, users have to enable its clock in the RCC\_AHBEN register.

*Note:* When a 16-bit or 8-bit access is performed on an APB register, the access will be transformed into a 32-bit access, and the bridge duplicates the 8-bit or 32-bit data to feed the 32-bit vector.

### **1.1.2 ARM Cortex®-M4F Processer**

Cortex<sup>®</sup>-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 for deeply-embedded applications that require quick response to interruption. Cortex<sup>®</sup>-M4F processor is based on ARMv7-M architecture, and it supports both Thumb instruction set and DSP instruction set. Cortex<sup>®</sup>-M4F processor also provides the following systems and peripherals:



Internal bus matrix, which is used for the interconnect between I-Code bus, D-Code bus, System bus, Private Peripheral Bus (PPB), and debug access (AHB-AP):

- Nested Vectored Interrupt Controller (NVIC)
- Flash Patch and Breakpoint (FPB)
- Memory Protection Unit (MPU)
- Data Watchpoint and Trace (DWT)
- Serial Wire JTAG Debug Port (SWJ-DP)

Figure 1-2 shows the internal block diagram of  $Cortex^{\mathbb{R}}$ -M4F processor. Please refer to "ARM  $Cortex^{\mathbb{R}}$ -M4 Technical Reference Manual" for more information.

Figure 1-2 Internal Block Diagram of Cortex®-M4F



## 1.2 Address Map

Program memory, data memory, registers, and I/O ports are organized within the same linear 4-GB address space. The bytes are coded in memory in Little Endian format. The lowest numbered byte in a word is considered the least significant byte of the word, and the highest numbered byte will be the most



significant.

For the detailed mapping information of peripheral registers, please refer to the related sections. The addressable memory space is divided into 8 main blocks, each of which is 512 MB. All the memory areas that are not allocated to on-chip memories and peripherals are reserved address spaces. Please refer to the diagram of memory map listed in the corresponding data sheet of the user device.

Figure 1-3 V84XXX Address Configuration



#### **Register Map** 1.2.1

Please refer to the diagram of memory map listed in the corresponding data sheet of the user device. Table 1-1 lists all the peripheral boundary addresses in V84XXX.

Table 1-1 Register Boundary Address

**ango** 

| Boundary Address         | Peripherals             | Bus        | Register Map  |
|--------------------------|-------------------------|------------|---------------|
| 0A000 1000 - 0xFFFF FFFF | Reserved                | АНВ        |               |
| 0A000 0000 - 0xA000 0FFF | XMC_REG                 |            | refer to 18.4 |
| Hango H                  | angzhou Vango Technolog | jies, Inc. | 28 / 782      |

|                           |                         | 1    |                 |
|---------------------------|-------------------------|------|-----------------|
| 0x6000 0000 - 0x9FFF FFFF | XMC_MEM                 |      | refer to 18.4   |
| 0x4002 A000 - 0x5FFF FFFF | Reserved                |      |                 |
| 0x4002 8000 - 0x4002 9FFF | Reserved                |      |                 |
| 0x4002 3400 - 0x4002 7FFF | Reserved                |      |                 |
| 0x4002 3000 - 0x4002 33FF | CRC                     |      | refer to 6.4    |
| 0x4002 2000 - 0x4002 23FF | Flash memory interface  |      | refer to 5.4    |
|                           | (FMC)                   |      |                 |
| 0x4002 1400 - 0x4002 1FFF | Reserved                |      |                 |
| 0x4002 1000 - 0x4002 13FF | Reset and clock control |      | refer to 3.3    |
|                           | (RCC)                   | _    |                 |
| 0x4002 0800 - 0x4002 0FFF | Reserved                |      |                 |
| 0x4002 0400 - 0x4002 07FF | DMA2                    |      | refer to 9.4    |
| 0x4002 0000 - 0x4002 03FF | DMA1                    |      | refer to 9.4    |
| 0x4001 8400 - 0x4001 7FFF | Reserved                |      |                 |
| 0x4001 8000 - 0x4001 83FF | Reserved                |      |                 |
| 0x4001 7400 - 0x4001 7FFF | Reserved                | APB2 |                 |
| 0x4001 7000 - 0x4001 73FF | Reserved                |      |                 |
| 0x4001 6C00 - 0x4001 6FFF | Reserved                |      |                 |
| 0x4001 6800 - 0x4001 6BFF | UART8                   |      | refer to 15.6   |
| 0x4001 6400 - 0x4001 67FF | UART7                   |      | refer to 15.6   |
| 0x4001 6000 - 0x4001 63FF | USART6                  |      | refer to 15.6   |
| 0x4001 5C00 - 0x4001 5FFF | Reserved                |      |                 |
| 0x4001 5800 - 0x4001 5BFF | Reserved                |      |                 |
| 0x4001 5400 - 0x4001 57FF | TMR11 Timer             |      | refer to 10.3.5 |
| 0x4001 5000 - 0x4001 53FF | TMR10 Timer             |      | refer to 10.3.5 |
| 0x4001 4C00 - 0x4001 4FFF | TMR9 Timer              |      | refer to 10.3.4 |
| 0x4001 4400 - 0x4001 4BFF | Reserved                |      |                 |
| 0x4001 4000 - 0x4001 43FF | Reserved                |      |                 |



|                           |                                   | _ |
|---------------------------|-----------------------------------|---|
| 0x4001 3C00 - 0x4001 3FFF | Reserved                          |   |
| 0x4001 3800 - 0x4001 3BFF | USART1                            |   |
| 0x4001 3400 - 0x4001 37FF | TMR8 Timer                        |   |
| 0x4001 3000 - 0x4001 33FF | SPI1/I2S1                         |   |
| 0x4001 2C00 - 0x4001 2FFF | TMR1 Timer                        |   |
| 0x4001 2800 - 0x4001 2BFF | Reserved                          |   |
| 0x4001 2400 - 0x4001 27FF | ADC1                              |   |
| 0x4001 2000 - 0x4001 23FF | Reserved                          |   |
| 0x4001 1C00 - 0x4001 1FFF | Reserved                          |   |
| 0x4001 1800 - 0x4001 1BFF | GPIO Port E                       |   |
| 0x4001 1400 - 0x4001 17FF | GPIO Port D                       |   |
| 0x4001 1000 - 0x4001 13FF | GPIO Port C                       |   |
| 0X4001 0C00 - 0x4001 0FFF | GPIO Port B                       |   |
| 0x4001 0800 - 0x4001 0BFF | GPIO Port A                       |   |
| 0x4001 0400 - 0x4001 07FF | EXTI                              |   |
| 0x4001 0000 - 0x4001 03FF | AFIO                              |   |
| 0x4000 8400 - 0x4000 FFFF | Reserved                          |   |
| 0x4000 7800 - 0x4000 83FF | USB 1280-byte SRAM <sup>(1)</sup> |   |
| 0x4000 7400 - 0x4000 77FF | Reserved                          |   |
| 0x4000 7000 - 0x4000 73FF | Power control (PWR)               |   |
| 0x4000 6C00 - 0x4000 6FFF | Backup registers (BKPR)           |   |
| 0x4000 6800 - 0x4000 6BFF | 12C3                              |   |
| 0x4000 6400 - 0x4000 67FF | CAN                               |   |
| 0x4000 6000 - 0x4000 63FF | USB 512-byte SRAM <sup>(1)</sup>  |   |
| 0x4000 5C00 - 0x4000 5FFF | USB device FS registers           |   |
| 0x4000 5800 - 0x4000 5BFF | 12C2                              |   |
| 0x4000 5400 - 0x4000 57FF | I2C1                              |   |
| 0x4000 5000 - 0x4000 53FF | UART5                             |   |
|                           |                                   |   |

| refer to 15.6   |
|-----------------|
| refer to 10.4.4 |
| refer to 16.4   |
| refer to 10.4.4 |
|                 |
| refer to 13.4   |
|                 |
|                 |
| refer to 7.5    |
| refer to 8.3    |
| refer to 7.5    |
|                 |
| refer to 19.3.2 |
|                 |
| refer to 2.4    |
| refer to 4.4    |
| refer to 14.4   |
| refer to 17.4   |
| refer to 19.3.2 |
| refer to 19.4   |
| refer to 14.4   |
| refer to 14.4   |
| refer to 15.6   |

APB1



| UART4                |                                                   | refer to 15.6                                                                                                                                                                                                                   |
|----------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| USART3               |                                                   | refer to 15.6                                                                                                                                                                                                                   |
| USART2               |                                                   | refer to 15.6                                                                                                                                                                                                                   |
| SPI4/I2S4            |                                                   | refer to 16.4                                                                                                                                                                                                                   |
| SPI3/I2S3            |                                                   | refer to 16.4                                                                                                                                                                                                                   |
| SPI2/I2S2            |                                                   | refer to 16.4                                                                                                                                                                                                                   |
| Reserved             |                                                   |                                                                                                                                                                                                                                 |
| Independent watchdog |                                                   | refer to 11.2.4                                                                                                                                                                                                                 |
| (IWDG)               |                                                   |                                                                                                                                                                                                                                 |
| Window watchdog      |                                                   | refer to 11.1.6                                                                                                                                                                                                                 |
| (WWDG)               |                                                   |                                                                                                                                                                                                                                 |
| RTC                  |                                                   | refer to 12.4                                                                                                                                                                                                                   |
| Reserved             |                                                   |                                                                                                                                                                                                                                 |
| TMR14 Timer          |                                                   | refer to 10.3.5                                                                                                                                                                                                                 |
| TMR13 Timer          |                                                   | refer to 10.3.5                                                                                                                                                                                                                 |
| TMR12 Timer          |                                                   | refer to 10.3.4                                                                                                                                                                                                                 |
| TMR7 Timer           |                                                   | refer to 10.1.4                                                                                                                                                                                                                 |
| TMR6 Timer           |                                                   | refer to 10.1.4                                                                                                                                                                                                                 |
| TMR5 Timer           |                                                   | refer to 10.2.4                                                                                                                                                                                                                 |
| TMR4 Timer           |                                                   | refer to 10.2.4                                                                                                                                                                                                                 |
| TMR3 Timer           |                                                   | refer to 10.2.4                                                                                                                                                                                                                 |
| TMR2 Timer           |                                                   | refer to 10.2.4                                                                                                                                                                                                                 |
|                      | Independent watchdog<br>(IWDG)<br>Window watchdog | USART3<br>USART2<br>SPI4/I2S4<br>SPI3/I2S3<br>SPI2/I2S2<br>Reserved<br>Independent watchdog<br>(IWDG)<br>Window watchdog<br>(WWDG)<br>RTC<br>Reserved<br>TMR14 Timer<br>TMR13 Timer<br>TMR12 Timer<br>TMR12 Timer<br>TMR5 Timer |

Note: 1.When USB768B = 0, SRAM size is 512 bytes, its address is 0x4000 6000 ~ 0x4000 63FF. When USB768B = 1, SRAM configuration is 1024 ~ 1280 bytes, its address is 0x40007800 ~ 0x400083FF. When CAN is not enabled, the USB packet buffer can be set to a maximum of 1280 bytes, and when CAN is enabled, the USB packet buffer can be set to a maximum of 1024 bytes.



## 1.2.2 Bit Banding

The Cortex<sup>®</sup>-M4F memory map includes two bit-band regions. These regions map each word in an alias region of memory to a bit in a bit-band region of memory. Writing to a word in the alias region has the same effect as a read-modify-write operation on the targeted bit in the bit-band region.

In the V84XXX series, both peripheral registers and SRAM are mapped in a bit-band region. This allows single bit-band write and read operations to be performed.

The following mapping formula shows how to reference each word in the alias region to a corresponding bit in the bit-band region. The mapping formula is:

bit\_word\_addr = bit\_band\_base + (byte\_offset × 32) + (bit\_number × 4)

where:

bit\_word\_addr: The address of the word in the alias memory region, and it maps to certain targeted bit. bit\_band\_base: The starting address of the alias region

byte\_offset: The number of the byte in the bit-band region that contains the targeted bit bit\_number: The bit position (0-31) of the targeted bit

Example:

The following example shows how to map bit 2 of the byte located at SRAM address 0x20000200 in the alias region:

 $bit_word_addr = 0x2200_0000 + (0x200 \times 32) + (2 \times 4) = 0x2200_4008$ 

Writing to address 0x2200\_4008 has the same effect as a read-modify-write operation on bit 2 of the byte at SRAM address 0x2000\_0200. Reading address 0x2200\_4008 returns the value (0x0000\_0001 or 0x0000\_0000) of bit 2 of the byte at SRAM address 0x2000\_0200. For more information on bit-banding, please refer to "ARM<sup>®</sup> Cortex-M4 Technical Reference Manual."

## 1.2.3 On-chip SRAM

The V84XXX series has built-in 1024K bytes of on-chip SRAM, the starting address is 0x2000\_0000. It can be accessed in bytes, half words (16 bits) or full words (32 bits). The V84XXX series also provides a special mode that can allocate 384K of on-chip SRAM to the zero wait state flash memory, expanding its



capacity to 512K bytes. The user can set the extended option byte EOPB bit 0 to use this extended mode (see section 5.3.4).

In 1024KB mode, the flash memory capacity with zero wait state is limited to 128K bytes;

In 640KB mode, the flash memory capacity with zero wait state is limited to 512K bytes.

## 1.2.4 On-chip Flash

V84XXX series provide up to 5120 KB of on-chip Flash memory, supporting zero wait state single cycle 32-bit read operation. The Flash memory is divided into main memory block and information block. The main memory block is used for storing application code; it can be accessed by bytes (8-bit aligned), half-words (16-bit aligned), or full words (32-bit aligned). The Flash memory can be programmed as 16 bits (half-word) or 32 bits (full words) at a time. The main block consists of Pages, each of which is 2 KB/4KB(V8411N Bank 3). The Flash memory erase operation can be performed at Page level or on the whole Flash area (mass-erase) (The mass-erase does not affect the information blocks.). Information block contains system memory and option byte. System memory is used for storing boot loader, which is programmed in the factory, and users cannot modify it. Option bytes store the options that users can modify. For detailed information, please refer to Table 1-2.

Flash memory is controlled by Flash memory controller. The controller provides prefetch buffer, option byte loader, Flash program/erase operation, and Read/Write protection. Please refer to <u>Chapter 5</u> for more details about Flash memory controller and register configuration.

|                                             | Block | Name    | Address Range             | Size (bytes) |
|---------------------------------------------|-------|---------|---------------------------|--------------|
|                                             |       | Page0   | 0x0800 0000 – 0x0800 07FF | 2 K          |
|                                             |       | Page1   | 0x0800 0800 – 0x0800 0FFF | 2 K          |
|                                             |       | Page2   | 0x0800 1000 - 0x0800 17FF | 2 K          |
| Main<br>Bank 1<br>Memory<br>512 KB<br>Block | -     | Page3   | 0x0800 1800 - 0x0800 1FFF | 2 K          |
|                                             |       | Page4   | 0x0800 2000 – 0x0800 27FF | 2 K          |
|                                             |       |         |                           |              |
|                                             |       |         |                           |              |
|                                             |       | Page255 | 0x0807 F800 – 0x0807 FFFF | 2 K          |

Table 1-2 Flash Memory Module Organization (V8411N)



|                 |          | Page256           | 0x0808 0000 – 0x0808 07FF | 2 K  |
|-----------------|----------|-------------------|---------------------------|------|
|                 |          | Page257           | 0x0808 0800 - 0x0808 0FFF | 2 K  |
|                 |          | Page258           | 0x0808 1000 - 0x0808 17FF | 2 K  |
| Bank            | 2        | Page259           | 0x0808 1800 - 0x0808 1FFF | 2 K  |
| 512 k           | КВ       | Page260           | 0x0808 2000 – 0x0808 27FF | 2 K  |
|                 |          |                   |                           |      |
|                 |          |                   |                           |      |
|                 |          | Page511           | 0x080F F800 – 0x080F FFFF | 2 K  |
| Banl            | k 3      |                   | 0x0840 0000 – 0x087F FFFF | 4M   |
|                 |          | Boot Loader       | 0x1FFF B000 – 0x1FFF F7FF | 16 K |
| Information Blo | CK       | User Option bytes | 0x1FFF F800 – 0x1FFF F80F | 48   |
|                 |          | FLASH_ACR         | 0x4002 2000 – 0x4002 2003 | 4    |
|                 |          | FLASH_FCKEY       | 0x4002 2004 – 0x4002 2007 | 4    |
|                 |          | FLASH_OPTKEYR     | 0x4002 2008 – 0x4002 200B | 4    |
|                 |          | FLASH_STS         | 0x4002 200C – 0x4002 200F | 4    |
|                 |          | FLASH_CTRL        | 0x4002 2010 - 0x4002 2013 | 4    |
|                 |          | FLASH_ADDR        | 0x4002 2014 – 0x4002 2017 | 4    |
|                 |          | Reserved          | 0x4002 2018 – 0x4002 201B | 4    |
|                 |          | FLASH_UOB         | 0x4002 201C - 0x4002 201F | 4    |
| Flash Memory I  | nterface | FLASH_WRPRT       | 0x4002 2020 – 0x4002 2023 | 4    |
| Register        |          | Reserved          | 0x4002 2024 - 0x4002 2043 | 32   |
|                 |          | FLASH_FCKEY2      | 0x4002 2044 - 0x4002 2047 | 4    |
|                 |          | Reserved          | 0x4002 2048 - 0x4002 204B | 4    |
|                 |          | FLASH_STS2        | 0x4002 204C - 0x4002 204F | 4    |
|                 |          | FLASH_CTRL2       | 0x4002 2050 - 0x4002 2053 | 4    |
|                 |          | FLASH_ADDR2       | 0x4002 2054 - 0x4002 2057 | 4    |
|                 |          | Reserved          | 0x4002 2058 - 0x4002 2083 | 44   |
|                 |          | FLASH_FCKEY3      | 0x4002 2084 - 0x4002 2087 | 4    |
|                 |          | FLASH_SELECT      | 0x4002 2088 - 0x4002 208B | 4    |



| FLASH_STS3  | 0x4002 208C - 0x4002 208F | 4  |
|-------------|---------------------------|----|
| FLASH_CTRL3 | 0x4002 2090 - 0x4002 2093 | 4  |
| FLASH_ADDR3 | 0x4002 2094 - 0x4002 2097 | 4  |
| FLASH_DA    | 0x4002 2098 – 0x4002 209B | 4  |
| Reserved    | 0x4002 209C - 0x4002 20F3 | 88 |
| CRC_DR      | 0x4002 20F4 - 0x4002 20F7 | 4  |
| CRC_OUTR    | 0x4002 20F8 - 0x4002 2FB  | 4  |

### Table 1-3 Flash Memory Module Organization (V8410N and V8411S)

| Block             |                | Name              | Address Range             | Size (bytes) |
|-------------------|----------------|-------------------|---------------------------|--------------|
|                   |                | Page 0            | 0x0800 0000 – 0x0800 07FF | 2K           |
|                   |                | Page 1            | 0x0800 0800 - 0x0800 0FFF | 2K           |
|                   |                | Page 2            | 0x0800 1000 - 0x0800 17FF | 2K           |
|                   | Bank 1         | Page 3            | 0x0800 1800 - 0x0800 1FFF | 2K           |
|                   | 512 KB         | Page 4            | 0x0800 2000 - 0x0800 27FF | 2K           |
|                   |                |                   |                           |              |
|                   |                |                   |                           |              |
| Main              |                | Page 255          | 0x0807 F800 – 0x0807 FFFF | 2K           |
| Memoy             |                | Page 256          | 0x0808 0000 – 0x0808 07FF | 2K           |
| Block             |                | Page 257          | 0x0808 0800 – 0x0808 0FFF | 2K           |
|                   |                | Page 258          | 0x0808 1000 – 0x0808 17FF | 2К           |
|                   | bank 2         | Page 259          | 0x0808 1800 – 0x0808 1FFF | 2K           |
|                   | 512KB          | Page 260          | 0x0808 2000 – 0x0808 27FF | 2K           |
|                   |                |                   |                           |              |
|                   |                |                   |                           |              |
|                   |                | Page 511          | 0x080F F800 – 0x080F FFFF | 2К           |
| Information Block |                | Boot Loader       | 0x1FFF B000 – 0x1FFFEFFF  | 16K          |
|                   |                | User Option bytes | 0x1FFF F800 – 0x1FFF F82F | 48           |
| Flash Mer         | mory Interface | FLASH_ACR         | 0x4002 2000 – 0x4002 2003 | 4            |
| Register          |                | FLASH_FCKEY       | 0x4002 2004 – 0x4002 2007 | 4            |



| FLASH_OPTKEYR | 0x4002 2008 – 0x4002 200B | 4   |
|---------------|---------------------------|-----|
| FLASH_STS     | 0x4002 200C – 0x4002 200F | 4   |
| FLASH_CTRL    | 0x4002 2010 – 0x4002 2013 | 4   |
| FLASH_ADDR    | 0x4002 2014 – 0x4002 2017 | 4   |
| Reserved      | 0x4002 2018 – 0x4002 201B | 4   |
| FLASH_UOB     | 0x4002 201C - 0x4002 201F | 4   |
| FLASH_WRP RT  | 0x4002 2020 – 0x4002 2023 | 4   |
| Reserved      | 0x4002 2024 - 0x4002 2043 | 32  |
| FLASH_FCKE Y2 | 0x4002 2044 - 0x4002 2047 | 4   |
| Reserved      | 0x4002 2048 - 0x4002 204B | 4   |
| FLASH_STS2    | 0x4002 204C - 0x4002 204F | 4   |
| FLASH_CTRL2   | 0x4002 2050 - 0x4002 2053 | 4   |
| FLASH_ADDR2   | 0x4002 2054 - 0x4002 2057 | 4   |
| Reserved      | 0x4002 2058 - 0x4002 20F3 | 156 |
| CRC_DR        | 0x4002 20F4 - 0x4002 20F7 | 4   |
| CRC_OUTR      | 0x4002 20F8 - 0x4002 2FB  | 4   |

### Table 1-4 Flash Memory Module Organization (V8410C)

| Block          |        | Name     | Address Range             | Size (bytes) |
|----------------|--------|----------|---------------------------|--------------|
|                |        | Page 0   | 0x0800 0000 – 0x0800 07FF | 2К           |
|                |        | Page 1   | 0x0800 0800 – 0x0800 0FFF | 2К           |
|                |        | Page 2   | 0x0800 1000 – 0x0800 17FF | 2К           |
|                | Bank 1 | Page 3   | 0x0800 1800 – 0x0800 1FFF | 2К           |
| Main           | 512 KB | Page 4   | 0x0800 2000 – 0x0800 27FF | 2К           |
| Memoy<br>Block |        |          |                           |              |
| Diock          |        |          |                           |              |
|                |        | Page 255 | 0x0807 F800 – 0x0807 FFFF | 2К           |
|                | Bank 2 | Page 256 | 0x0808 0000 – 0x0808 07FF | 2К           |
|                | 512KB  | Page 257 | 0x0808 0800 – 0x0808 0FFF | 2К           |



|                     |              | Page 258                               | 0x0808 1000 - 0x0808 17FF | 2К       |
|---------------------|--------------|----------------------------------------|---------------------------|----------|
|                     |              | Page 259                               | 0x0808 1800 - 0x0808 1FFF | 2К       |
|                     |              | Page 260                               | 0x0808 2000 – 0x0808 27FF | 2К       |
|                     |              |                                        |                           |          |
|                     |              |                                        |                           |          |
|                     |              | Page 511                               | 0x080F F800 – 0x080F FFFF | 2К       |
| External<br>storage | Bank3        |                                        | 0x0840 0000 – 0x093F FFFF | 16M      |
|                     |              | Boot Loader                            | 0x1FFF B000 – 0x1FFF EFFF | 16K      |
| Information         | Block        | User Option<br>bytes                   | 0x1FFF F800 – 0x1FFF F82F | 48       |
|                     |              | FLASH_ACR                              | 0x4002 2000 – 0x4002 2003 | 4        |
|                     |              | FLASH_FCKY                             | 0x4002 2004 – 0x4002 2007 | 4        |
|                     |              | FLASH_OPTKEYR                          | 0x4002 2008 – 0x4002 200B | 4        |
|                     |              | FLASH_STS                              | 0x4002 200C - 0x4002 200F | 4        |
|                     |              | FLASH_CTRL                             | 0x4002 2010 - 0x4002 2013 | 4        |
|                     |              | FLASH_ADDR                             | 0x4002 2014 - 0x4002 2017 | 4        |
|                     |              | Reserved                               | 0x4002 2018 - 0x4002 201B | 4        |
|                     |              | FLASH_UOB                              | 0x4002 201C - 0x4002 201F | 4        |
| Flash Memo          | ry Interface | FLASH_WRPRT                            | 0x4002 2020 - 0x4002 2023 | 4        |
| Register            |              | Reserved                               | 0x4002 2024 - 0x4002 2043 | 32       |
|                     | FLASH_FCKEY2 |                                        | 0x4002 2044 - 0x4002 2047 | 4        |
|                     | Reserved     |                                        | 0x4002 2048 - 0x4002 204B | 4        |
|                     |              | FLASH_STS2                             | 0x4002 204C - 0x4002 204F | 4        |
|                     |              | FLASH_CTRL2                            | 0x4002 2050 - 0x4002 2053 | 4        |
|                     |              | FLASH_ADDR2                            | 0x4002 2054 - 0x4002 2057 | 4        |
|                     |              | Reserved 0x4002 2058 - 0               |                           | 44       |
|                     |              | FLASH_FCKEY3 0x4002 2084 - 0x4002 2087 |                           | 4        |
|                     |              | FLASH_SELECT                           | 0x4002 2088 - 0x4002 208B | 4        |
|                     |              |                                        | ango Tochnologiog. Inc    | 27 / 702 |

| FLASH_STS3  | 0x4002 208C - 0x4002 208F | 4  |
|-------------|---------------------------|----|
| FLASH_CTRL3 | 0x4002 2090 - 0x4002 2093 | 4  |
| FLASH_ADDR3 | 0x4002 2094 - 0x4002 2097 | 4  |
| FLASH_DA    | 0x4002 2098 – 0x4002 209B | 4  |
| Reserved    | 0x4002 209C - 0x4002 20F3 | 88 |
| CRC_DR      | 0x4002 20F4 - 0x4002 20F7 | 4  |
| CRC_OUTR    | 0x4002 20F8 - 0x4002 2FB  | 4  |

# **1.3 Boot Configuration**

V84XXX provides three kinds of boot sources which can be selected through the BOOT[1:0] pins. The details are shown in Table 1-5.

| Boot Mode         | Description                                  | Boot Mode Selection Pins |       |  |
|-------------------|----------------------------------------------|--------------------------|-------|--|
|                   | Description                                  | BOOT1                    | BOOT0 |  |
| Main Flash memory | Main Flash memory is selected as boot space. | Х                        | 0     |  |
| System memory     | System memory is selected as boot space.     | 0                        | 1     |  |
| On-chip SRAM      | Embedded SRAM is selected as boot space.     | 1                        | 1     |  |

The values on the BOOT pins are latched after reset. Users can set the BOOT1 and BOOT0 pins after reset, to select the required boot mode. The BOOT pins are re-sampled when exiting from the Standby mode. Therefore, they must be kept in the required boot mode configuration in the Standby mode.

Depending on the selected boot mode, main Flash memory, system memory, or SRAM are accessible as follows:

• Boot from main Flash memory: The main Flash memory is aliased in the boot memory space (0x0000 0000), but it is still accessible from its original memory space (0x800 0000). In other words, the Flash memory contents can be accessed starting from address 0x0000 0000 or 0x800 0000.

Boot from system memory: The system memory is aliased in the boot memory space (0x0000
 0000), but it is still accessible from its original memory space (0x1FFF F000 in other devices).



Boot from the embedded SRAM: SRAM is accessible only at address 0x2000 0000.

After startup delay, CPU fetches the top-of-stack value from address 0x0000 0000, and it starts executing code from the designated address 0x0000\_0004 of boot memory. Due to its fixed memory map, the code area starts from address 0x0000 0000 (accessed through the I-Code/D-Code buses) while the data area (SRAM) starts from address 0x2000 0000 (accessed through the system bus). Cortex<sup>®</sup>-M4F CPU always fetches the reset vector on the I-Code bus, which implies that boot space is available only in the code area (typically, Flash memory).

V84XXX series microcontrollers implement a special mechanism which enables booting from on-chip SRAM. When booting from on-chip SRAM, in the application initialization code, NVIC exception table and offset register must be used to relocate the vector table in SRAM.

System memory contains the embedded boot loader, which can be used for programming the Flash memory. Boot loader reprograms the Flash memory through USART1 interface.

# **1.4 Device Characteristics Information**

#### **1.4.1** Description of Register Abbreviations

The following abbreviations are used in the register descriptions of this manual:

| read/write (rw)    | Software can read and write to these bits.                                                          |
|--------------------|-----------------------------------------------------------------------------------------------------|
| read-only (r)      | Software can only read these bits.                                                                  |
| write-only (w)     | Software can only write to this bit. Reading the bit returns the reset value.                       |
| read/clear (rc_w0) | Software can read as well as clear this bit by writing 0. Writing `1' has no effect on the bit      |
|                    | value.                                                                                              |
| read/set (rs)      | Software can read as well as set this bit by writing 1. Writing '0' has no effect on the bit value. |
| Reserved (res)     | Reserved bit; it must be kept at reset value.                                                       |

Table 1-6 List of for Register Abbreviations

#### 1.4.2 Flash Memory Size Register

Flash memory size register can retrieve the information about chip Flash memory size, and users can



get the Flash memory size through this register.

#### Base address: 0x1FFF F7E0

#### Reset value: 0xXXXX (Factory-programmed)

| Bit     | Name   | Туре | Description                  |
|---------|--------|------|------------------------------|
| Bit15:0 | F_SIZE | r    | Flash memory size, in Kbytes |
|         |        |      | Example: 0x0080 = 128 Kbytes |



# **2 Power Control (PWR)**

# **2.1 Introduction**

Power consumption is one of the most important issue in V84XXX series devices. The operating voltage supply is 2.6 V  $\sim$  3.6 V, and it can function normally within -40°C  $\sim$  +85°C. To reduce power consumption and to achieve the best tradeoff among the conflicting demands of CPU operating time, speed, and power consumption, the Power Management Unit (PMU) provides three types of power saving modes, including Sleep, Deep-sleep, and Standby mode. For V84XXX series devices, there are three power domains, including VDD/VDDA domain, 1.2 V domain, and backup domain. The power of VDD/VDDA domain is supplied directly by external power; however, VDDA and VSSA provide separated analog module power to reduce noise on external power. An embedded LDO in the VDD/VDDA domain is used to supply the 1.2 V domain power.

# 2.2 Main Features

Three power domains:  $V_{DD}/V_{DDA}$  domain, core domain, and backup domain.

Three types of power saving modes: Sleep mode, Deep-sleep mode, and Standby mode. Internal voltage regulator supplies 1.2 V voltage source for core domain.

Low voltage detector is provided to issue an interrupt when the supply voltage is lower than a programmed threshold.

# **2.3 Function Overview**

### 2.3.1 Power Supply

The operating voltage (VDD) of V84XXX is 2.6 V  $\sim$  3.6 V. An embedded regulator is used to supply the internal 1.2 V power.

Figure 2-1 Block Diagram of Each Power Supply





#### 2.3.1.1 V<sub>DD</sub>/V<sub>DDA</sub> Power Domain

The operating voltage ( $V_{DD}$ ) of V84XXX is 2.6 V ~ 3.6 V. An embedded regulator is used to supply the internal 1.2 V power.

To increase the conversion accuracy, the ADC has an independent power supply which can filter and shield from noises on the PCB. The ADC voltage supply input is available on a separate  $V_{DDA}$  pin. An isolated supply ground connection is provided on the  $V_{SSA}$  pin.

V84XXX has an integrated internal POR/PDR circuitry that allows proper operation when the supply voltage reaches 2.6. When  $V_{DD}/V_{DDA}$  is below a specified threshold  $V_{POR}/V_{PDR}$ , the device remains in Reset mode, without the need for an external reset circuit. For more details concerning the power-on/power-down reset, please refer to the electrical characteristics section of the data sheet.

Figure 2-2 Power-on Reset/Power-down Reset Waveform



V84XXX provides a programmable voltage detector (PVD). Users can use this PVD to monitor VDD power supply by comparing it to the PVDS[2:0] bits in the power control register (PWR\_CTRL), selecting the threshold for voltage monitor.

The PVD is enabled by setting the PVDEN bit. The PVD bit in the power control/status register (PWR\_CTRLST) indicates whether VDD is higher or lower than the PVD threshold.

This event is internally connected to the EXTI line 16 and can generate an interrupt if it is enabled through the EXTI registers. When VDD drops below the PVD threshold and/or when VDD rises above the PVD threshold, the PVD output interrupt will be generated depending on the rising/falling edge of EXTI line16 configuration. This characteristic can be used to perform emergency power-down tasks.

Figure 2-3 PVD Threshold and Outputs





#### 2.3.1.2 Core Power Domain

Core power domain includes CPU core, memory, and embedded digital peripherals. This power domain is supplied by a voltage regulator. The voltage regulator is always enabled after reset. It works in three different modes depending on the application modes.

Run mode: The regulator supplies full power to the 1.2 V domain (core, memories, and digital peripherals).

Stop mode: The regulator supplies low power to the 1.2 V domain, preserving contents of registers and SRAM.

Standby mode: The regulator is powered off. The contents of the registers and SRAM are lost except for the backup circuitry and the backup domain.

Battery backup domain

The  $V_{BAT}$  pin also supplies power to the RTC unit, the LSE oscillator, and the PC13 to PC15 IOs.

Note: At  $V_{DD}$  startup phase ( $t_{RSTTEMPO}$ ) or after PVD is detected, the power switch between  $V_{BAT}$  and  $V_{DD}$  remains connected to  $V_{BAT}$ . At the startup phase, if  $V_{DD}$  is established in less than  $t_{RSTTEMPO}$  (Please refer to the data sheet for the value of  $t_{RSTTEMPO}$ ) and  $V_{DD} > V_{BAT} + 0.6$  V, a current may be injected into  $V_{BAT}$  through an internal diode connected between  $V_{DD}$  and the power switch ( $V_{BAT}$ ). If the power supply/battery connected to the  $V_{BAT}$  pin cannot support this current injection, connecting an external low-drop diode between this power supply and the  $V_{BAT}$  pin is strongly



#### recommended.

Connecting  $V_{BAT}$  externally to  $V_{DD}$  with a 100 nF ceramic decoupling capacitor is recommended. When the backup domain is supplied by  $V_{DD}$  (analog switch connected to  $V_{DD}$ ), the following functions are available:

• PC14 and PC15 can be used as either GPIO or LSE pins.

• PC13 can be used as GPIO, TAMPER pin, RTC calibration clock, RTC alarm or second output (Please refer to <u>Chapter 4</u>).

Note: Due to the fact that the analog switch only sinks a limited amount of current (3 mA), the use of GPIOs PC13 to PC15 in the output mode is restricted: the speed has to be limited to 2 MHz with a maximum load of 30 pF, and these IOs must not be used as a current source (e.g. To drive a LED).

The backup domain is supplied by  $V_{DD}/V_{BAT}$  for the following functions:

- PC14 and PC15 can only be used as LSE pins.
- PC13 can be used as TAMPER pin, RTC alarm, or second output (Please refer to Section 4.4.2.

#### 2.3.2 Low-power Mode

After a system or a power reset, the microcontroller is in Run mode by default. When the CPU does not need to be kept running, there are several low-power modes available to save power. For example, when waiting for an external event, users can select the mode that gives the best compromise according to the low-power consumption, short startup time, and available wakeup sources.

V84XXX provides three low-power modes:

• Sleep mode (Cortex<sup>®</sup>-M4F CPU clock off, all peripherals including Cortex<sup>®</sup>-M4F core peripherals like NVIC, SysTick, etc. are kept running)

- Stop mode (All clocks are stopped, except SysTick.)
- Standby mode (1.2 V domain powered-off)

| Mode            | Entry   | Wakeup        | Effect on 1.2 V | Effect on VDD | Voltage Regulator |
|-----------------|---------|---------------|-----------------|---------------|-------------------|
|                 | Lincity | Mancap        | Domain Clocks   | Domain Clocks |                   |
| Sleep (SLP-NOW  | WFI     | Any interrupt | CPU clock OFF,  |               |                   |
| or SLP-ON-EXIT) |         |               | no effect on    | None          | ON                |
|                 | WFE     | Wakeup        | other clocks or |               |                   |



|          |           | event          | ADC clock        |                             |                 |
|----------|-----------|----------------|------------------|-----------------------------|-----------------|
|          |           |                | sources          |                             |                 |
|          | PDDS bit  |                |                  |                             | ON or in        |
|          | +         | Any EXTI line  |                  |                             | low-power mode  |
| Stop     | SLEEPDEEP | (configured in |                  |                             | (depends on the |
| Stop     | bit       | the EXTI       |                  |                             | power control   |
|          | + WFI or  | registers)     |                  |                             | register        |
|          | WFE       |                | All 1.2 V domain | HSI and HSE oscillators are | (PWR_CTRL))     |
|          | PDDS bit  | WKUP pin       | clocks are OFF.  | OFF.                        |                 |
|          | +         | rising edge,   |                  | OFF.                        |                 |
| Chandley | SLEEPDEEP | RTC alarm,     |                  |                             |                 |
| Standby  | bit       | external reset |                  |                             | OFF             |
|          | + WFI or  | in NRST pin,   |                  |                             |                 |
|          | WFE       | IWDG reset     |                  |                             |                 |

In addition, the power consumption in Run mode can be reduced by one of the following methods:

• Slowing down the system clocks. In Run mode, the speed of system clock (SYSCLK, HCLK, PCLK1, and PCLK2) can be reduced by programming the prescaler registers. Before entering the Sleep mode, the prescalers can also be used to slow down peripheral clocks. Please refer to <u>Section 3.3.2</u> for more details.

• Gating the clocks of the APB and AHB peripherals when they are unused. In Run mode, peripherals and memories clocks (HCLK and PCLKx) can be stopped at any time to reduce power consumption. To further reduce power consumption in Sleep mode, all the peripheral clocks can be disabled before executing the WFI or WFE instructions. Peripheral clock gating is controlled by configuring AHB peripheral clock (which enables the RCC\_AHBEN register), APB2 peripheral clock (which enables the RCC\_APB1EN register).

#### 2.3.2.1 Sleep Mode

Entering Sleep mode:

The Sleep mode is entered by executing WFI or WFE instructions. According to the SLEEPONEXIT bit in the Cortex<sup>®</sup>-M4F system control register, there are two options to select the Sleep mode entry



mechanism:

• SLP-NOW: If the SLEEPONEXIT bit is cleared, the MCU enters Sleep mode as soon as WFI or WFE instruction is executed.

• SLP-ON-EXIT: If the SLEEPONEXIT bit is set, the MCU enters Sleep mode as soon as it exits the lowest priority ISR.

In the Sleep mode, all I/O pins keep the same state as in the Run mode. Please refer to Table 2-1 and Table 2-2 for more details on how to enter Sleep mode.

Exiting Sleep mode

If the WFI instruction is executed to enter Sleep mode, any peripheral interrupt acknowledged by the nested vectored interrupt controller (NVIC) can wake up the device from Sleep mode.

If the WFE instruction 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 an interrupt in the peripheral control register instead of in the NVIC, and enabling the SEVONPEND bit in the Cortex<sup>®</sup>-M4F system control register. When the MCU resumes from WFE, the peripheral interrupt pending bit and the peripheral NVIC IRQ channel pending bit (in the NVIC interrupt clear pending register) need to be cleared.

• Configuring an external or internal EXTI line in event mode. When the MCU resumes from WFE, since the pending bit corresponding to the event line is not set, it is not necessary to clear the peripheral interrupt pending bit or the NVIC IRQ channel pending bit.

The wakeup time required by this mode is the shortest, since there is no time wasted in interrupt entry/exit. Please refer to Table 2-1 and Table 2-2 for more details on how to exit Sleep mode.

| Aango        | Hangzhou Vango Technologies, Inc. 47 / 782                                 |
|--------------|----------------------------------------------------------------------------|
|              | If WFE was executed for entry: Wakeupevent: Refer to Wakeup event          |
| Exit         | vectors (Table 8-1)                                                        |
|              | If WFI was executed for entry: Interrupt: Refer to Interrupt and exception |
|              | Refer to the Cortex $^{\textcircled{R}}$ -M4F system control register.     |
| Entry        | - SLEEPDEEP = 0 and SLEEPONEXIT = 0                                        |
|              | WFI (Wait for Interrupt) or WFE (Wait for Event) while:                    |
| SLP-NOW Mode | Description                                                                |

Table 2-1 SLP-NOW Mode

ango

| management (Section 8.2.3) |  |
|----------------------------|--|
| Wakeup latency None        |  |

Table 2-2 SLP-ON-EXIT Mode

| SLP-ON_EXIT Mode Description |                                                                 |
|------------------------------|-----------------------------------------------------------------|
|                              | Execute WFI while:                                              |
| Entry                        | - SLEEPDEEP = 0 and $-$ SLEEPONEXIT = 1                         |
|                              | Refer to the Cortex <sup>®</sup> -M4F system control register.  |
| Exit                         | Interrupt: Refer to Interrupt and exception vectors (Table 8-1) |
| Wakeup latency               | None                                                            |

#### 2.3.2.2 Stop Mode

The Stop mode is based on the Cortex<sup>®</sup>-M4F Deep-sleep mode and combined with peripheral clock gating. In Stop mode, the voltage regulator can operate normally either in normal or low-power mode. At this time, all clocks in the 1.2 V domain are stopped, the PLL, the HSI, and the HSE RC oscillators are disabled. SRAM and register contents are preserved.

In the Stop mode, all I/O pins keep the same state as in the Run mode.

#### 2.3.2.2.1 Entering Stop mode

Please refer to Table 2-3 for details on how to enter the Stop mode.

If Flash memory programming is ongoing, Stop mode entry is delayed until the memory access is finished. If an access to the APB domain is ongoing, the Stop mode entry is delayed until the APB access is finished. The following features can be selected by programming individual control bits:

• Independent watchdog (IWDG): IWDG is started by writing to its Key register or by hardware option. Once started, it cannot be stopped except by reset. Please refer to <u>Section 11.2.3</u>.

• Real-time clock (RTC): This is configured by the RTCEN bit in the backup domain control register (RCC\_BDCR)

• Internal RC oscillator (LSI RC): This is configured by the LSION bit in the control/status register (RCC\_CTRLSTS).

• External 32.768 kHz oscillator (LSE): This is configured by the LSEON bit in the backup domain control register (RCC\_BDC).



In Stop mode, peripherals such as the ADC still consume power if they are not turned off before entering Stop mode. To disable them, the ADON bit in the ADC\_CR2 register must be written to 0.

#### 2.3.2.2.2 Exiting Stop mode

Please refer to Table 2-3 for more details on how to exit Stop mode.

When exiting Stop mode by issuing an interrupt or a wakeup event, the HSI RC oscillator is selected as the system clock.

When the voltage regulator operates in low-power mode, an additional startup delay is incurred when aking up from Stop mode. By keeping the internal regulator ON in Stop mode, the consumption increased as the startup time is reduced.

#### Table 2-3 Stop Mode

| Stop mode      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Entry          | <ul> <li>Execute WFI (Wait for Interrupt) or WFE (Wait for Event) while:</li> <li>Set SLEEPDEEP bit in Cortex<sup>®</sup>-M4F system control register.</li> <li>Clear PDDS bit in power control register (PWR_CTRL).</li> <li>Note: To enter Stop mode, all EXTI Line pending bits (in the Pending register (EXTI_PR)), all peripheral interrupt pending bits, and RTC alarm flag must be reset.</li> <li>Otherwise, the program will skip the entry process of Stop mode to continue to execute the following procedure.</li> </ul> |
| Exit           | If WFI was executed for entry:<br>Configure any EXTI Line as Interrupt mode (the corresponding EXTI interrupt<br>vector must be enabled in the NVIC). Please refer to interrupt and exception<br>vectors (Table 8-1).<br>If WFE was used for entry:<br>Configure any EXTI Line as event mode.<br>Please refer to wakeup event management (Section 8.2.3).                                                                                                                                                                            |
| Wakeup latency | HSI RC wakeup time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### 2.3.2.3 Standby Mode

Standby mode can achieve the lowest power consumption for the device. This mode is based on the



Cortex<sup>®</sup>-M4F Deep-sleep mode, with the voltage regulator disabled. The whole 1.2 V domain is poweroff. The PLL, the HSI oscillator, and the HSE oscillator are also switched off. SRAM and register contents are lost. Only registers in the backup domain and standby circuitry remain supplied (Please refer to Figure 2-1).

#### 2.3.2.3.1 Entering Standby mode

Please refer to Table 2-4 for more details on how to enter Standby mode. In Standby mode, the following features can be selected by programming individual control bits:

• Independent watchdog (IWDG): IWDG is started by writing to its Key register or by hardware option. Once started, it cannot be stopped except by reset. See Section 11.2.3.

• Real-time clock (RTC): This is configured by the RTCEN bit in the backup domain control register (RCC\_BDCR).

• Internal RC oscillator (LSI RC): This is configured by the LSIEN bit in the control/ status register (RCC\_CTRLSTS).

• External 32.768 kHz oscillator (LSE OSC): This is configured by the LSEEN bit in the backup domain control register (RCC\_BDC).

#### 2.3.2.3.2 Exiting Standby mode

The microcontroller exits the Standby mode when an external reset (NRST pin), an IWDG reset, a rising edge on the WKUP pin, or the rising edge of an RTC alarm occurs (See Figure 12-1). All registers are reset after waking up from Standby mode except for the power control/status register (PWR\_CTRLSTS) (See Section 2.4.2). After waking up from Standby mode, the program executes the instruction code in the same way as after reset (boot pins sampling, vector reset is fetched, etc.). The power control/status register (PWR\_CTRLSTS) (See Section 2.4.2) will instruct the MCU to exit from the Standby mode.

Table 2-4 Standby Mode

| Standby Mode | Description                                                                             |
|--------------|-----------------------------------------------------------------------------------------|
| Entry        | Execute WFI (Wait for Interrupt) or WFE (Wait for Event) while:                         |
|              | <ul> <li>Set SLEEPDEEP bit in Cortex<sup>®</sup>-M4F system control register</li> </ul> |
|              | <ul> <li>Set PDDS bit in power control register (PWR_CTRL)</li> </ul>                   |
|              | <ul> <li>Clear WUF bit in power control/status register (PWR_CTRLSTS)</li> </ul>        |



| Exit           | Rising edge of the WKUPx( $x=1,2,3,4$ ) pin, rising edge of the RTC alarm event, |
|----------------|----------------------------------------------------------------------------------|
|                | external reset in NRST pin, IWDG reset                                           |
| Wakeup latency | T <sub>rsttempo</sub>                                                            |

#### 2.3.2.3.3 I/O states in Standby mode

In Standby mode, all I/O pins are high impedance except for:

- Reset pad (still available)
- The TAMPER pin if configured for tamper or calibration out
- The WKUP pin, if enabled

#### 2.3.2.4 Debug Mode

By default, the debug connection is lost if the MCU is in Stop or Standby mode while debugging. This is because Cortex<sup>®</sup>-M4F core is no longer clocked. However, by setting some configuration bits in the DBGMCU\_CTRL register, the software can be debugged even in the low-power modes. For more details, please refer to <u>Section 20.2.1</u>.

### 2.3.3 Auto-wakeup (AWU)

The RTC can wake up the MCU from the low-power mode without an external interrupt (Auto-wakeup mode). The RTC provides a programmable time base for waking up from Stop or Standby mode at regular intervals. Two of the three RTC clock sources can be selected to perform this function by programming the RTCSEL[1:0] bits in the backup domain control register (RCC\_BDC):

#### Low-power 32.768 kHz external crystal oscillator (LSE)

This clock source provides a precise time base with very low power consumption (typically less than  $1 \mu A$ ).

#### Low-power internal RC oscillator (LSI RC)

When being used, this clock source saves the cost of the 32.768 kHz crystal. However, the power consumed by the RC Oscillator may slightly increases.

To wake up the device from Stop mode with an RTC alarm event, it is necessary to:

#### Configure the EXTI Line 17 as rising edge trigger



#### Configure the RTC to generate the RTC alarm

To wake up from Standby mode, there is no need to configure the EXTI Line 17.

# 2.4 PWR Registers

### 2.4.1 Power Control Register (PWR\_CTRL)

Address offset: 0x000

Reset value: 0x0000 0000 (Reset by waking up from Standby mode.)

| Bit      | Name      | Туре | Description                                                                                                                                                                                                                                                                                                                                                                           |  |
|----------|-----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 31:9 | -         | -    | Reserved. Always read as 0.                                                                                                                                                                                                                                                                                                                                                           |  |
| Bit 8    | DBP       | rw   | Disable backup domain write protection<br>After reset, the RTC and backup registers are protected against<br>unwanted write access. This bit must be set to enable write access to<br>these registers.<br>0: Access to RTC and backup registers is disabled.<br>1: Access to RTC and backup registers is enabled.<br>Note: If HSE/128 is used as the RTC clock, this bit must be set. |  |
| Bit 7:5  | PVDS[2:0] | rw   | PVD level selection<br>These bits are used to select the voltage threshold detected by the<br>power voltage detector 000: Reserved 100: 2.6 V<br>001: 2.3 V<br>010: 2.4 V<br>010: 2.4 V<br>011: 2.5 V<br>101: 2.7 V<br>110: 2.8 V<br>111: 2.9 V<br>Note: Please refer to the electrical characteristics of the data sheet for<br>more details.                                        |  |
| Bit 4    | PVDEN     | rw   | Power voltage detector (PVD) enable                                                                                                                                                                                                                                                                                                                                                   |  |



|       |       |       | 0: PVD is disabled.<br>1: PVD is enabled.                                                                                                                                                                            |
|-------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 3 | CLSBF | rc_w1 | Clear standby flag This bit is always read as 0.                                                                                                                                                                     |
| Bit 2 | CLWUF | rc_w1 | Clear wakeup flag This bit is always read as 0.<br>0: No effect<br>1: Clear the WUF wakeup flag after 2 system clock cycles. (Write)                                                                                 |
| Bit 1 | PDDS  | rw    | Power down Deep-sleep<br>0: Enter Stop mode when the CPU enters Deep-sleep.<br>1: Enter Standby mode when the CPU enters Deep-sleep.                                                                                 |
| Bit 0 | LPDS  | rw    | Low power consumption in Deep-sleep mode When PDDS = 0, it<br>operates with the PDDS bit.<br>0: Voltage regulator is enabled in the Stop mode.<br>1: Voltage regulator is in low power consumption in the Stop mode. |

# 2.4.2 Power Control/Status Register (PWR\_CTRLSTS)

Address offset: 0x004

Reset value: 0x0000 0000 (Not reset by waking up from Standby mode.)

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

| Bit       | Name                                          | Туре | Description                                                            |  |  |  |
|-----------|-----------------------------------------------|------|------------------------------------------------------------------------|--|--|--|
| Bit 31:12 | -                                             | -    | Reserved. Always read as 0.                                            |  |  |  |
|           | WUP4EN                                        | rw   | Enable WKUPF pin                                                       |  |  |  |
|           |                                               |      | 0: WKUP4 pin is used for general purpose I/O. An event on the WKUP4    |  |  |  |
|           |                                               |      | pin does not wake up the CPU from Standby mode.                        |  |  |  |
| Bit 11    |                                               |      | 1: WKUP4 pin is used for waking up the CPU from Standby mode, and is   |  |  |  |
|           |                                               |      | forced in input pull-down configuration. (Rising edge on the WKUP4 pin |  |  |  |
|           |                                               |      | wakes up the system from Standby mode.)                                |  |  |  |
|           |                                               |      | Note: This bit is reset by a system reset.                             |  |  |  |
| Man       | AngoHangzhou Vango Technologies, Inc.53 / 782 |      |                                                                        |  |  |  |

|         |        | 1  |                                                                         |
|---------|--------|----|-------------------------------------------------------------------------|
|         |        |    | Note: Before enabling WKUP4 pin, please configure PC4 to analog input   |
|         |        |    | mode                                                                    |
|         | WUP3EN | rw | Enable WKUP3 pin                                                        |
|         |        |    | 0: WKUP3 pin is used for general purpose I/O. An event on the WKUP3     |
|         |        |    | pin does not wake up the CPU from Standby mode.                         |
|         |        |    | 1: WKUP3 pin is used for waking up the CPU from Standby mode, and is    |
| Bit 10  |        |    | forced in input pull-down configuration. (Rising edge on the WKUP3 pin  |
|         |        |    | wakes up the system from Standby mode.)                                 |
|         |        |    | Note: This bit is reset by a system reset.                              |
|         |        |    | Note: Before enabling WKUP3 pin, please configure PC0 as analog input   |
|         |        |    | mode                                                                    |
|         | WUP2EN | rw | Enable WKUPF pin                                                        |
|         |        |    | 0: WKUP2 pin is used for general purpose I/O. An event on the WKUP2     |
|         |        |    | pin does not wake up the CPU from Standby mode.                         |
|         |        |    | 1: WKUP2 pin is used for waking up the CPU from Standby mode, and is    |
| Bit 9   |        |    | forced in input pull- down configuration. (Rising edge on the WKUP2 pin |
|         |        |    | wakes up the system from Standby mode.)                                 |
|         |        |    | Note: This bit is reset by a system reset.                              |
|         |        |    | Note: Before enabling WKUP2 pin, please configure PA1 as analog input   |
|         |        |    | mode                                                                    |
|         | WUP1EN | rw | Enable WKUPF pin                                                        |
|         |        |    | 0: WKUP1 pin is used for general purpose I/O. An event on the WKUP1     |
|         |        |    | pin does not wake up the CPU from Standby mode.                         |
| Bit 8   |        |    | 1: WKUP1 pin is used for waking up the CPU from Standby mode, and is    |
|         |        |    | forced in input pull- down configuration. (Rising edge on the WKUP1 pin |
|         |        |    | wakes up the system from Standby mode.)                                 |
|         |        |    | Note: This bit is reset by a system reset.                              |
| Bit 7:3 | -      | -  | Reserved. Always read as 0.                                             |
|         | PVD    | r  | PVD output                                                              |
| Bit 2   |        |    | This bit is valid only if PVD is enabled by the PVDEN bit.              |
|         |        |    | 0: VDD/VDDA is higher than the PVD threshold selected by the PLS[2:0]   |
|         | 1      | 1  | 1                                                                       |



|       |     |   | bits. 1: VDD/VDDA is lower than the PVD threshold selected by the        |
|-------|-----|---|--------------------------------------------------------------------------|
|       |     |   |                                                                          |
|       |     |   | PLS[2:0] bits.                                                           |
|       |     |   | Note: The PVD is stopped in Standby mode. Hence, this bit remains 0      |
|       |     |   | after Standby or reset until the PVDEN bit is set.                       |
|       | SBF | r | Standby flag                                                             |
|       |     |   | This bit is set by hardware and can only be cleared by a POR/PDR (Power- |
| Bit 1 |     |   | on reset/power-down reset bit) or by setting the CSBF bit in the power   |
|       |     |   | control register (PWR_CTRL).                                             |
|       |     |   | 0: Device is not in Standby mode. 1: Device is in Standby mode.          |
| Bit 0 | WUF | r | Wakeup flag                                                              |
|       |     |   | This bit is set by hardware and can only be cleared by a POR/PDR         |
|       |     |   | (Power-on reset/power- down reset bit) or by setting the CLWUF bit in    |
|       |     |   | the power control register (PWR_CTRL).                                   |
|       |     |   | 0: No wakeup event occurred.                                             |
|       |     |   | 1: A wakeup event was received from the WKUPF pin or from the RTC        |
|       |     |   | alarm.                                                                   |
|       |     |   | Note: An additional wakeup event is detected if the WKUPF pin is         |
|       |     |   | enabled (by setting the WUPEN bit) when the WKUPF pin level is already   |
|       |     |   | high.                                                                    |



# 3 Reset and Clock Control (RCC)

# 3.1 Reset

V84XXX provides three types of reset, including system reset, power-on reset, and backup domain reset.

### 3.1.1 System Reset

Except for the reset flags in the RCC\_CTRLSTS register of clock controller and the registers in the backup domain, a system reset sets all registers to their reset values (See Figure 2-1).

A system reset is generated when one of the following events occurs:

1. A low level on the NRST pin (external reset)

2. Window watchdog end of count condition (WWDG reset)

3. Independent watchdog end of count condition (IWDG reset)

4. A software reset (SW reset)

5. Low-power management reset

The reset source can be identified by checking the reset flags in the control/status register (RCC\_CTRLSTS).

Software reset:

By setting the SYSRESETREQ bit in Cortex<sup>®</sup>-M4F Application Interrupt and Reset Control Register, software reset can be launched. Please refer to the Cortex<sup>®</sup>-M4 programming manual for further information.

Low-power management reset:

There are two ways to generate a low-power management reset:

1. Reset generated when entering Standby mode: This type of reset is enabled by setting the nSTDBY\_RST bit in User Option Bytes. In this case, whenever a Standby mode entry sequence is successfully executed, the device is reset instead of entering Standby mode.

2. Reset generated when entering Stop mode: This type of reset is enabled by setting the nSTP\_RST bit in User Option Bytes. In this case, whenever a Stop mode entry sequence is successfully executed, the



device is reset instead of entering Stop mode.

#### 3.1.2 Power Reset

A power reset is generated when one of the following events occurs:

- 1. Power-on/Power-down reset (POR/PDR reset)
- 2. When exiting Standby mode

A power reset sets all registers to their reset values except the backup domain (see Figure 2-1).

The reset sources act on the RESET pin, and it is always kept low at the reset phase. The RESET service routine vector is fixed at address 0x0000\_0004 on the memory map.

The system reset signal provided to the device is outputted on the NRST pin. The pulse generator guarantees a minimum reset pulse duration of 20  $\mu$ s for each reset source (external or internal reset). In cases of an external reset, the reset pulse is generated while the NRST pin is asserted low.

Figure 3-1 Reset Circuit



#### 3.1.3 Backup Domain Reset

The backup domain has two specific resets that affect only the backup domain (See Figure 2-1). A backup domain reset is generated when one of the following events occurs:

1. Software reset, triggered by setting the BDRST bit in the backup domain control register (RCC\_BDC) (See Section 3.3.9).

2.  $V_{\text{DD}}$  or  $V_{\text{BAT}}$  power on, if both supplies have previously been powered off.



# **3.2 Clocks**

Three different clock sources can be used to drive the system clock (SYSCLK):

- HSI oscillator clock
- HSE oscillator clock
- PLL clock

The devices have the following two secondary clock sources:

• 40 kHz low-speed internal RC which drives the independent watchdog, and the RTC is used for autowakeup from Stop/Standby mode.

• 32.768 kHz low-speed external crystal (LSE crystal) which drives the Real Time Clock (RTCCLK).

Each clock source can be switched on or off independently when it is not used, to optimize power consumption.

Figure 3-2 V84XXX Clock Tree





1. When the HSI is used as a PLL clock input, the maximum system clock frequency that can be achieved is 180 MHz.

2. For the internal and external clock source characteristics, please refer to the "Electrical characteristics" section in the corresponding device data sheet.

Several prescalers allow the configuration of the AHB frequency, the high-speed APB (APB2) and the lowspeed APB (APB1) domain frequency. The maximum frequency of the AHB domain is 180 MHz. The maximum frequency of the APB1 and the APB2 domains is 90 MHz. The interface is clocked with a fixed frequency of HCLK/2.

The RCC feeds the Cortex<sup>®</sup> System Timer (SysTick) external clock with the AHB clock (HCLK) divided

by 8. The SysTick can work either with this clock or with the Cortex<sup>®</sup> clock (HCLK), configurable in the



SysTick Control and Status Register. The ADCs are clocked by the clock of the high-speed domain APB2 divided by 2, 4, 6, 8, 12, or 16.

The timer clock frequencies are automatically fixed by hardware depending on the two conditions:

1. If the APB prescaler is 1, the timer clock frequencies are set to the same frequency as that of the APB domain to which the timers are connected.

2. Otherwise, they are set to double (×2) the frequency of the APB domain to which the timers are connected.

FCLK acts as Cortex<sup>®</sup>-M4F's free-running clock. For more details, please refer to ARM Cortex<sup>®</sup>-M4 Technical Reference Manual.

### 3.2.1 HSE Clock

The high-speed external clock signal (HSE) can be generated from two possible clock sources:

- HSE external crystal/ceramic resoator
- HSE user external clock

To minimize the output distortion and startup stabilization time, the resonator and the load capacitors have to be placed as close as possible to the oscillator pins. The loading capacitance values must be adjusted according to the selected oscillator.

Figure 3-3 HSE/LSE Clock Sources





#### 3.2.1.1 External source (HSE bypass)

In this mode, an external clock source must be provided. Its frequency can be up to 25 MHz. Users can select this mode by setting the HSEBYPS and HSEEN bits in the clock control register. The external clock signal (square, sinus, or triangle with ~50% duty cycle) should be connected to the OSC\_IN pin while the OSC\_OUT pin should be left HiZ. See Figure 3-3.

#### 3.2.1.2 External crystal/ceramic resonator (HSE crystal)

The 4  $\sim$  25 MHz external oscillator produces a highly accurate clock source as the system clock. Relevant hardware configuration is shown in Figure 3-3. Please refer to the electrical characteristics section of the data sheet for more details.

The HSESTBL bit in the clock control register (RCC\_CTRL) indicates if the high-speed external oscillator is stable. When powered up, the clock is not released until this bit is set by hardware. An interrupt can be generated if enabled in the clock interrupt register (RCC\_CLKINT).

The HSE crystal can be switched on and off by configuring the HSEEN bit in the clock control register (RCC\_CTRL).

### 3.2.2 HSI Clock

system clock or divided by 2 to be used as PLL input.

The HSI RC oscillator can provide the system a clock source without any external components. Its startup time is shorter than the HSE crystal oscillator; however, even with calibration, its clock frequency is still less accurate.

RC oscillator frequencies can vary from one chip to another due to manufacturing process variations, and this is why each device is calibrated for 1% accuracy (25 °C) in factory. After reset, the factory calibration value is loaded in the HSICAL[7:0] bits of the clock control register. HSICAL[7:0] can be reconfigured by software (HSICAL\_KEY needs to be set as 0x5A). Once configured by software, a system reset is necessary to reload factory calibration value.

The RC oscillator speed may be affected by voltage or temperature variations. HSI frequency can be trimmed by using the HSITWK[5:0] bits in the clock control register.

The HSISTBL bit in the clock control register indicates if the HSI RC is stable. When the clock is powered up, the HSI RC output clock is not released until this bit is set by hardware.

The HSI RC can be switched on and off by using the HSIEN bit in the clock control register. If the HSE crystal oscillator fails, the HSI clock can be used as a backup source. Please refer to <u>Section 3.2.7.</u>

#### 3.2.3 PLL

The internal PLL can multiply HSI RC output clock or HSE crystal output clock. Please refer to Figure 3-2 and clock control register.

The configuration of PLL (selecting the clock source of HSI oscillator divided by 2 or HSE oscillator and selecting multiplication factor) must be done before enabling the PLL. Once the PLL is enabled, these parameters cannot be changed.

If PLL interrupt is enabled in the clock interrupt register, an interrupt can be generated when the PLL is ready. If USB interface is used in the application, PLL should be set as output 48, 72, 96, 120, 144, 168, to provide 48 MHz USBCLK clock.

#### 3.2.4 LSE Clock

The LSE crystal is a 32.768 kHz low-speed External crystal or ceramic resonator. It provides highly accurate clock source to the real-time clock or other timing functions with low power consumption.



The LSE crystal is switched on and off by using the LSEEN bit in backup domain control register (RCC\_BDC). The LSESTBL bit in backup domain control register (RCC\_BDC) indicates if the LSE crystal is stable. When powered up, the LSE crystal output clock signal is not released until this bit is set by hardware. An interrupt can be generated if enabled in the Clock interrupt register.

External source (LSE bypass)

In this mode, an external clock source with the frequency of 32.768 kHz must be provided. Users can select this mode by setting the LSEBYP and LSEON bits in the backup domain control register (RCC\_BDC). The external clock signal (square, sinus, or triangle with ~50% duty cycle) has to connect to the OSC32\_IN pin while the OSC32\_OUT pin should be left HiZ. See Figure 3-3.

#### 3.2.5 LSI Clock

The LSI RC acts as a low-power clock source that can be kept running in Stop and Standby mode for the independent watchdog (IWDG) and auto-wakeup unit (AWU). The clock frequency is around 40 KHz (between 30 KHz and 60 KHz). For more details, please refer to the electrical characteristics section of the data sheet.

The LSI RC can be switched on and off by using the LSIEN bit in the control/ status register (RCC\_CTRLSTS). The LSISTBL bit in the control/status register (RCC\_CTRLSTS) indicates if the low-speed internal oscillator is stable. When powered up, the clock is not released until this bit is set by hardware. An LSI interrupt can be generated if enabled in the clock interrupt register (RCC\_CLKINT).

The frequency dispersion of the low-speed internal (LSI) oscillator can be calibrated to obtain RTC time base and IWDG timeout (when LSI is used as clock source for these peripherals) with an acceptable accuracy.

This calibration can be done by measuring the LSI clock frequency with TIM5 input clock (TIM5\_CLK).

According to this measurement done at the precision of the HSE oscillator, the software can adjust the programmable 20-bit prescaler of the RTC to obtain an accurate RTC clock time base and compute accurate IWDG timeout.

LSI calibration procedures are as follows:

1. Enable TMR5 and configure channel 4 in input capture mode.

2. Set the TMR5\_CH4\_IREMAP bit in the AFIO\_MAP to internally connect the LSI to channel 4 of TMR5.



3. Measure the frequency of LSI clock with the TIMR5 capture/compare 4 event or interrupt.

4. Configure the 20-bit prescaler according to the measured and desired RTC time base and IWDG timeout.

#### 3.2.6 System Clock (SYSCLK) Selection

After a system reset, the HSI oscillator is selected as system clock. When a clock source is used directly or indirectly through the PLL as the system clock, it cannot be stopped.

A switch from one clock source to another occurs only if the target clock source is ready (the clock becomes stable after startup delay or PLL becomes stable). If the selected clock source is not ready, the switch will not occur until the target clock source is ready.

Status bits in the clock control register (RCC\_CTRL) indicate which clock is ready and which clock is currently used as system clock.

#### 3.2.7 Clock Failure Detection (CFD)

Clock Failure Detection can be activated by software. Once activated, the clock detector is enabled after the HSE oscillator startup delay, and disabled when this oscillator is stopped.

If a failure is detected on the HSE clock, the HSE oscillator is automatically disabled; a clock failure event is sent to the break input of the advanced control timer (TMR1 and TMR8), and a clock failure detection interrupt (CFDI) is generated to allow the device to perform rescue operation. The CFDI is linked to the

Cortex<sup>®</sup>-M4F NMI (Non-Maskable Interrupt).

Note: Once the CFD is enabled, the CFD interrupt occurs if the HSE clock fails, and an NMI is automatically generated. The NMI will be executed indefinitely unless the CFD interrupt pending bit is cleared. As a consequence, in the NMI ISR, users must clear the CFD interrupt by setting the CFDFC bit in the clock interrupt register (RCC\_CLKINT).

If the HSE oscillator is used directly or indirectly as the system clock ("indirectly" means that it is used as PLL input clock, and the PLL clock is used as system clock), a detected failure will cause a switch of the system clock to the HSI oscillator and disabling of the external HSE oscillator at the same time. When the failure occurs, if the HSE oscillator clock (divided or not) is the clock entry of the PLL used as system clock, the PLL will also be disabled.



### 3.2.8 RTC Clock

By programming the RTCSEL[1:0] bits in the backup domain control register (RCC\_BDC), the RTCCLK clock source can be provided by HSE/128, LSE, or LSI clocks. This selection cannot be changed without resetting the backup domain.

The LSE clock is in the backup domain, whereas the HSE and LSI clocks are not. Consequently:

- If LSE is selected as RTC clock:
  - The RTC continues to work as long as VBAT supply is maintained.
- If LSI is selected as Auto-Wakeup Unit (AWU) clock:

 The AWU state is not guaranteed if the VDD supply is powered off. Please refer to <u>Section 3.2.5</u> for more details on LSI calibration.

• If the HSE clock divided by 128 is used as RTC clock:

 The RTC state is not guaranteed if the VDD supply is powered off or if the internal voltage regulator is powered off (1.2 V domain power supply is cut off).

— The DPB bit (disable backup domain write protection) in the power controller register (See Section 2.4.1 ) must be set.

### 3.2.9 Watchdog Clock

If the Independent watchdog (IWDG) is started by either hardware option or software access, the LSI oscillator is forced ON and cannot be disabled. After the LSI oscillator temporization, the clock is provided to the IWDG.

### 3.2.10 Clock-out Capability

The microcontroller allows the clock to be outputted onto the external CLKOUT pin. The corresponding GPIO port register must be programmed as the corresponding function mode. The following 9 clock signals can be selected as CLKOUT clock:

- ADC CLK
- USB48M
- SYSCLK



- LSI
- LSE
- HSI
- HSE
- PLL clock divided by 2
- PLL clock divided by 4

# **3.3 RCC Registers Description**

# 3.3.1 Clock Control Register (RCC\_CTRL)

#### Address offset: 0x00

Reset value: 0x0000 XX83, where X is undefined Access: No wait state. Word, half-word, and byte access.

| Bit       | Name    | Туре | Description                                                           |
|-----------|---------|------|-----------------------------------------------------------------------|
| Bit 30:26 | -       | -    | Reserved. Always read as 0.                                           |
| Bit 25    | PLLSTBL | r    | PLL clock ready flag                                                  |
|           |         |      | Set by hardware after PLL is locked.                                  |
|           |         |      | 0: PLL is unlocked.                                                   |
|           |         |      | 1: PLL is locked.                                                     |
| Bit 24    | PLLEN   | rw   | PLL enable                                                            |
|           |         |      | Set and cleared by software. Cleared by hardware when entering        |
|           |         |      | Stop or Standby mode. When PLL clock is used as or selected to        |
|           |         |      | become system clock, this bit cannot be cleared.                      |
|           |         |      | 0: PLL is OFF.                                                        |
|           |         |      | 1: PLL is ON.                                                         |
| Bit 23:20 | -       | -    | Reserved. Always read as 0.                                           |
| Bit 19    | CFDEN   | rw   | Clock Failure Detection enable                                        |
|           |         |      | Set and cleared by software to enable Clock Failure Detection.        |
|           |         |      | 0: Clock Failure Detection is OFF.                                    |
|           |         |      | 1: If the external 4 $\sim$ 16 MHz oscillator is ready, Clock Failure |



|          |             |    | Detection is ON.                                                             |
|----------|-------------|----|------------------------------------------------------------------------------|
|          |             |    | Detection is ON.                                                             |
|          |             |    |                                                                              |
| Bit 18   | HSEBYPS     | rw | External high-speed clock bypass                                             |
|          |             |    | Set and cleared by software to bypass the external crystal                   |
|          |             |    | oscillator. This bit can be written only if the HSE oscillator is            |
|          |             |    | disabled.                                                                    |
|          |             |    | 0: External 4 $\sim$ 16 MHz crystal oscillator is not bypassed.              |
|          |             |    | 1: External 4 $\sim$ 16 MHz crystal oscillator is bypassed.                  |
| Bit 17   | HSESTBL     | r  | External high-speed clock ready flag                                         |
|          |             |    | Set by hardware to indicate that the external 4 $\sim$ 16 MHz oscillator     |
|          |             |    | is stable. This bit needs 6 cycles of external $4{\sim}16$ MHz oscillator to |
|          |             |    | be cleared after HSEEN bit is reset.                                         |
|          |             |    | 0: External 4 $\sim$ 16 MHz oscillator is not ready.                         |
|          |             |    | 1: External 4 $\sim$ 16 MHz oscillator is ready.                             |
| Bit16    | HSEEN       | rw | External high-speed clock enable Set and cleared by software.                |
|          |             |    | When entering Stop or Standby mode, this bit is cleared by                   |
|          |             |    | hardware, and the 4 $\sim$ 16 MHz oscillator is disabled. When external      |
|          |             |    | 4 $\sim$ 16 MHz oscillator is used as or selected to become system           |
|          |             |    | clock, this bit cannot be cleared.                                           |
|          |             |    | 0: HSE oscillator is OFF.                                                    |
|          |             |    | 1: HSE oscillator is ON.                                                     |
| Bit 15:8 | HSICAL[7:0] | rw | Internal high-speed clock calibration                                        |
|          |             |    | These bits are initialized automatically when the system is powered          |
|          |             |    | up.                                                                          |
|          |             |    | This byte can be written only when HSICAL_KEY[7:0] is 0x5A.                  |
| Bit 7:2  | HSITWK[5:0] | rw | Internal high-speed clock trimming                                           |
|          |             |    | These bits are written by software to adjust internal high-speed             |
|          |             |    | clock, added to the HSICAL[7:0] values. These bits allow users to            |
|          |             |    | key in a trimming value that can adjust the frequency of the                 |
|          |             |    | internal HSI RC oscillator according to voltage and temperature              |
|          |             |    | variations. The default value is 32, which can trim the HSI bit to 48        |
|          |             |    |                                                                              |



|       |         |    | MHz ± 1%.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|---------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 1 | HSISTBL | r  | Internal high-speed clock ready flag<br>Set by hardware to indicate that the internal 48 MHz oscillators is<br>stable. After the HSIEN bit is cleared, this bit is cleared after 6<br>internal 48 MHz oscillator cycles.<br>0: Internal 48 MHz oscillator is not ready.<br>1: Internal 48 MHz oscillator is ready.                                                                                                                                                                   |
| Bit 0 | HSIEN   | rw | Internal high-speed clock enable Set and cleared by software.<br>When leaving Stop or Standby mode or in case of the external 4 ~<br>25 oscillator failure, this bit is set by hardware to enable the<br>internal 8 MHz RC oscillator. This bit cannot be cleared if the<br>internal 48 MHz oscillator is used directly or indirectly as system<br>clock or is selected to become the system clock.<br>0: Internal 48 MHz oscillator is OFF.<br>1: Internal 48 MHz oscillator is ON. |

# 3.3.2 Clock Configuration Register (RCC\_CFG)

Address offset: 0x04

Reset value: 0x0000 0000

Access: 0 to 2 wait state. Word, half-word, and byte access. 1 or 2 wait states are inserted only when the access occurs during a clock source switch.

| Bit       | Name            | Туре | Description                                                         |
|-----------|-----------------|------|---------------------------------------------------------------------|
|           |                 |      | PLL clock output range                                              |
| Bit 31    | PLLRANGE        | rw   | 0: PLL output $\leq$ 72 MHz                                         |
|           |                 |      | 1: PLL output > 72 MHz                                              |
|           |                 | rw   | Microcontroller clock output CLKOUT[3] is in bit 16 of the RCC_MISC |
| Bit 26:24 | :24 CLKOUT[3:0] |      | register. Set and cleared by software.                              |



|           |             |             | 0000: No clock output                                               |
|-----------|-------------|-------------|---------------------------------------------------------------------|
|           |             |             | 0000: No clock output                                               |
|           |             |             | 0001: Reserved                                                      |
|           |             |             | 0010: LSI clock output                                              |
|           |             |             | 0011: LSE clock output                                              |
|           |             |             | 0100: System clock (SYSCLK) output                                  |
|           |             |             | 0101: Internal RC oscillator clock (HSI) output                     |
|           |             |             | 0110: External RC oscillator clock (HSE) output                     |
|           |             |             | 0111: Output after PLL clock divided by 2                           |
|           |             |             | 1100: Output after PLL clock divided by 4                           |
|           |             |             | 1101: USB clock output                                              |
|           |             |             | 1110: ADC clock output                                              |
|           |             |             | Note: This clock output may be disconnected when powered up or      |
|           |             |             | during CLKOUT clock source switching.                               |
|           |             |             | -When the system clock is used as output to the CLKOUT pin, make    |
|           |             |             | sure that the frequency of output clock must not exceed 50 MHz (the |
|           |             |             | maximum I/O frequency).                                             |
|           |             |             | USB prescaler                                                       |
|           |             | rw          | Set and cleared by software to generate 48 MHz USB clock. This bit  |
|           |             |             | must be valid before enabling the USB clock in the RCC_APB1EN       |
|           |             |             | register. This bit cannot be cleared if USB clock is enabled.       |
|           |             |             | 000: PLL clock divided by 1.5 to be USB clock                       |
| Bit 27    |             |             | 001: PLL clock directly to be USB clock                             |
| Bit 23:22 | USBPSC[2:0] |             | 010: PLL clock divided by 2.5 to be USB clock                       |
|           |             |             | 011: PLL clock divided by 2 to be USB clock                         |
|           |             |             | 100: PLL clock divided by 3.5 to be USB clock                       |
|           |             |             | 101: PLL clock divided by 3 to be USB clock                         |
|           |             |             | 110: PLL clock divided by 4 to be USB clock                         |
|           |             |             | 111: PLL clock divided by 4 to be USB clock                         |
|           | PLLMUL[5:0] |             | PLL multiplication factor { Bit 30:29, Bit 21:18}                   |
| Bit 30:29 |             | MUL[5:0] rw | These bits are written by software to define the PLL multiplication |
| Bit 21:18 |             |             | factor. They can be written only when PLL is disabled.              |
|           |             |             | Note: PLLRANGE register must be configured with PLL output.         |
|           |             |             |                                                                     |

|           |             |    | 000000: PLL output x 2                                                 |
|-----------|-------------|----|------------------------------------------------------------------------|
|           |             |    | 000001: PLL output x 3                                                 |
|           |             |    | 000010: PLL output x 4                                                 |
|           |             |    | 000011: PLL output x 5                                                 |
|           |             |    |                                                                        |
|           |             |    | 001111: PLL output x 16                                                |
|           |             |    | 010000: PLL output x 17                                                |
|           |             |    |                                                                        |
|           |             |    | 111110: PLL output x 64                                                |
|           |             |    | HSE divider for PLL entry                                              |
|           |             |    | Set and cleared by software to divide HSE as PLL input clock. This bit |
| Bit 17    | PLLHSEPSC   | rw | can be written only when PLL is disabled.                              |
|           |             |    | 0: HSE is not divided.                                                 |
|           |             |    | 1: HSE is divided, divider is setting by HSE_DIV_CTRL .                |
|           |             |    | PLL entry clock source                                                 |
|           |             |    | Set and cleared by software to select PLL input clock source. This bit |
| Bit 16    | PLLRC       | rw | can be written only when PLL is disabled.                              |
|           |             |    | 0: HSI oscillator clock divided by 2 to be PLL input clock.            |
|           |             |    | 1: HSE clock is used as PLL input clock                                |
|           |             |    | ADC prescaler                                                          |
|           |             |    | ADCPSC[2], Set by bit 28                                               |
|           |             |    | Set and cleared by software to define ADC clock frequency.             |
|           |             |    | 000: PCLK2 divided by 2 to be ADC clock                                |
|           | ADCPSC[2:0] |    | 001: PCLK2 divided by 4 to be ADC clock                                |
| Bit 28    |             |    | 010: PCLK2 divided by 6 to be ADC clock                                |
| Bit 15:14 |             |    | 011: PCLK2 divided by 8 to be ADC clock                                |
|           |             |    | 100: PCLK2 divided by 2 to be ADC clock                                |
|           |             |    | 101: PCLK2 divided by 12 to be ADC clock                               |
|           |             |    | 110: PCLK2 divided by 8 to be ADC clock                                |
|           |             |    | 111: PCLK2 divided by 16 to be ADC clock                               |
| Bit 13:11 | APB2PSC[2:0 | rw | APB high-speed prescaler (APB2)                                        |
| L         |             |    |                                                                        |



|          | ]           |    | Set and cleared by software to control the division factor of high-   |
|----------|-------------|----|-----------------------------------------------------------------------|
|          | -           |    | speed APB2 clock (PCLK2). Caution: These bits must be configured      |
|          |             |    | by software to ensure that the frequency of APB2 clock is less than   |
|          |             |    | 90 MHz.                                                               |
|          |             |    | 0xx: HCLK is not divided.                                             |
|          |             |    | 100: HCLK is divided by 2.                                            |
|          |             |    | 101: HCLK is divided by 4.                                            |
|          |             |    | 110: HCLK is divided by 8.                                            |
|          |             |    | 111: HCLK is divided by 16.                                           |
|          |             |    | APB low-speed prescaler (APB1)                                        |
|          |             | rw | Set and cleared by software to control the division factor of low-    |
|          |             |    | speed APB1 clock (PCLK1). Caution: These bits must be configured      |
|          |             |    | by software to ensure that the frequency of APB1 clock is less than   |
|          | APB1PSC[2:0 |    | 90 MHz.                                                               |
| Bit 10:8 | 1           |    | 0xx: HCLK is not divided.                                             |
|          | J           |    | 100: HCLK is divided by 2.                                            |
|          |             |    | 101: HCLK is divided by 4.                                            |
|          |             |    | 110: HCLK is divided by 8.                                            |
|          |             |    | 111: HCLK is divided by 16.                                           |
|          |             |    |                                                                       |
|          |             |    | AHB prescaler                                                         |
|          |             | rw | Set and cleared by software to control the division factor of AHB     |
|          |             |    | clock 0xxx: SYSCLK is not divided.                                    |
|          |             |    | 1000: SYSCLK is divided by 2                                          |
|          |             |    | 1001: SYSCLK is divided by 4                                          |
|          |             |    | 1010: SYSCLK is divided by 8                                          |
| Bit 7:4  | AHBPSC[3:0] |    | 1011: SYSCLK is divided by 16                                         |
|          |             |    | 1100: SYSCLK is divided by 64                                         |
|          |             |    | 1101: SYSCLK is divided by 128                                        |
|          |             |    | 1110: SYSCLK is divided by 256                                        |
|          |             |    | 1111: SYSCLK is divided by 512                                        |
|          |             |    | Note: The prefetch buffer must be kept ON when the division factor of |
|          |             |    | AHB clock is higher than 1.                                           |

Hangzhou Vango Technologies, Inc.

| Bit 3:2 | SYSCLKSTS[<br>1:0] | r  | System clock switch status                                            |
|---------|--------------------|----|-----------------------------------------------------------------------|
|         |                    |    | Set and cleared by hardware to indicate which clock source is used as |
|         |                    |    | system clock.                                                         |
|         |                    |    | 00: HSI used as system clock                                          |
|         |                    |    | 01: HSE used as system clock                                          |
|         |                    |    | 10: PLL output used as system clock                                   |
|         |                    |    | 11: Not allowed                                                       |
| Bit 1:0 | SYSCLKSEL[1<br>:0] | rw | System clock switch                                                   |
|         |                    |    | Set and cleared by software to select system clock source. HSI as     |
|         |                    |    | system clock will be forced by hardware (if the clock security system |
|         |                    |    | is enabled) when leaving Stop and Standby mode or failure of HSE      |
|         |                    |    | used directly or indirectly as system clock is detected.              |
|         |                    |    | 00: HSI used as system clock                                          |
|         |                    |    | 01: HSE used as system clock                                          |
|         |                    |    | 10: PLL output used as system clock                                   |
|         |                    |    | 11: Not allowed                                                       |

# 3.3.3 Clock Interrupt Register (RCC\_CLKINT)

Address offset: 0x08

Reset value: 0x0000 0000

Access: No wait state. Word, half-word, and byte access.

| Bit       | Name  | Туре | Description                                                      |
|-----------|-------|------|------------------------------------------------------------------|
| Bit 31:24 | -     | -    | Reserved. Always read as 0.                                      |
| Bit 23    | CFDFC | w    | Clock failure detection interrupt clear                          |
|           |       |      | Write 1 by software to clear the CFDF interrupt flag in the CFDF |
|           |       |      | security system                                                  |
|           |       |      | 0: No effect                                                     |
|           |       |      | 1: Clear the CFDF security system interrupt flag                 |
| Bit 22:21 | -     | -    | Reserved. Always read as 0.                                      |



| -         |           | 1  |                                                                    |
|-----------|-----------|----|--------------------------------------------------------------------|
| Bit 20    | PLLSTBLFC | w  | PLL ready interrupt clear                                          |
|           |           |    | Write 1 by software to clear the PLL ready interrupt flag          |
|           |           |    | PLLSTBLF                                                           |
|           |           |    | 0: No effect                                                       |
|           |           |    | 1: Clear the PLL ready interrupt flag PLLSTBLF                     |
| Bit 19    | HSESTBLFC | w  | HSE ready interrupt clear                                          |
|           |           |    | Write 1 by software to clear the HSE ready interrupt flag          |
|           |           |    | HSESTBLF                                                           |
|           |           |    | 0: No effect                                                       |
|           |           |    | 1: Clear the HSE ready interrupt flag HSESTBLF                     |
| Bit 18    | HSISTBLFC | w  | HSI ready interrupt clear                                          |
|           |           |    | Write 1 by software to clear the HSI ready interrupt flag          |
|           |           |    | HSISTBLF                                                           |
|           |           |    | 0: No effect                                                       |
|           |           |    | 1: Clear the HSI ready interrupt flag HSISTBLF                     |
| Bit 17    | LSESTBLFC | w  | LSE ready interrupt clear                                          |
|           |           |    | Write 1 by software to clear the LSE ready interrupt flag          |
|           |           |    | LSESTBLF                                                           |
|           |           |    | 0: No effect                                                       |
|           |           |    | 1: Clear the LSE ready interrupt flag LSESTBLF                     |
| Bit 16    | LSISTBLFC | w  | LSI ready interrupt clear                                          |
|           |           |    | Write 1 by software to clear the LSI ready interrupt flag          |
|           |           |    | LSISTBLF                                                           |
|           |           |    | 0: No effect                                                       |
|           |           |    | 1: Clear the LSI ready interrupt flag LSISTBLF                     |
| Bit 15:13 |           | -  | Reserved. Always read as 0.                                        |
| Bit 12    | PLLSTBLIE | rw | PLL ready interrupt enable                                         |
|           |           |    | Setand clearedby software to enable/disable the PLL readyinterrupt |
|           |           |    | 0: PLL ready interrupt is disabled.                                |
|           |           |    | 1: PLL ready interrupt is enabled.                                 |
| L         | 1         | 1  | 1                                                                  |



| Bit 11       HSESTBLIE       rw       HSE ready interrupt enable         Set and cleared by software to enable/disable external 4~16 MHz       oscillator ready interrupt is disabled.         Bit 10       HSISTBLIE       rw       HSI ready interrupt is disabled.         Bit 10       HSISTBLIE       rw       HSI ready interrupt is enabled.         Bit 10       HSISTBLIE       rw       HSI ready interrupt is disabled.         Bit 10       LSESTBLIE       rw       HSI ready interrupt is disabled.         Bit 9       LSESTBLIE       rw       LSE ready interrupt is enabled.         Bit 9       LSESTBLIE       rw       LSE ready interrupt is disabled.         Bit 9       LSESTBLIE       rw       LSE ready interrupt enable         Bit 9       LSESTBLIE       rw       LSE ready interrupt is disabled.         Bit 8       LSISTBLIE       rw       LSE ready interrupt is disabled.         Bit 8       LSISTBLIE       rw       LSE ready interrupt is enabled.         Bit 7       CIOK Failure Detection interrupt is disabled.       I: LSE ready interrupt is disabled.         Bit 6:5       CFDF       r       Clock Failure Detection interrupt fing         Bit 6:5       ICDF       r       Clock Failure Detection interrupt is caused by HSE clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |           | 1  |                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------|----|------------------------------------------------------------------------|
| Bit 10HSISTBLIErw<br>aHSI ready interrupt is disabled.<br>1: HSE ready interrupt is enabled.Bit 10HSISTBLIErw<br>aHSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 8 MHz RC<br>oscillator ready interrupt<br>0: HSI ready interrupt is disabled.<br>1: HSI ready interrupt is enabled.Bit 9LSESTBLIErw<br>aLSE ready interrupt enable<br>Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt is enabled.<br>1: HSI ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErw<br>LSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5I-Reserved. Always read as 0.Bit 6:5PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                     | Bit 11  | HSESTBLIE | rw | HSE ready interrupt enable                                             |
| Bit 10HSISTBLIEIVHSI ready interrupt is disabled.<br>1: HSE ready interrupt is enabled.Bit 10HSISTBLIErwHSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 8 MHz RC<br>oscillator ready interrupt<br>0: HSI ready interrupt is disabled.<br>1: HSI ready interrupt is enabled.Bit 9LSESTBLIErwLSE ready interrupt enable<br>Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt is disabled.<br>1: LSE ready interrupt is disabled.<br>1: LSI ready interrupt is disabled.<br>1: L |         |           |    | Set and cleared by software to enable/disable external $4{\sim}16$ MHz |
| Bit 10HSISTBLIErwHSI ready interrupt is enabled.Bit 10HSISTBLIErwHSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 8 MHz RC<br>oscillator ready interrupt<br>0: HSI ready interrupt is disabled.<br>1: HSI ready interrupt is enabled.Bit 9LSESTBLIErwLSE ready interrupt is enabled.<br>0: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is disabled.<br>0: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt is disabled.<br>0: LSE ready interrupt is enabled.<br>0: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt<br>0: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5Bit 6:5Bit 6:5Bit 4PLLSTBLFrBit 4PLLSTBLFrBit 4PLLSTBLFset by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                         |         |           |    | oscillator ready interrupt                                             |
| Bit 10HSISTBLIErwHSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 8 MHz RC<br>oscillator ready interrupt<br>0: HSI ready interrupt is disabled.<br>1: HSI ready interrupt is enabled.Bit 9LSESTBLIErwLSE ready interrupt enable<br>Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt is enabled.<br>1: HSI ready interrupt is enabled.<br>Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt is disabled.<br>1: LSE ready interrupt is enable/<br>0: LSI ready interrupt is enable/<br>0: LSI ready interrupt is enable/<br>0: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt<br>0: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                             |         |           |    | 0: HSE ready interrupt is disabled.                                    |
| HSISTBLIErwHSI ready interrupt enableSet and cleared by software to enable/disable internal 8 MHz RC<br>oscillator ready interrupt0: HSI ready interruptBit 9LSESTBLIErwLSE ready interrupt is disabled.<br>1: HSI ready interrupt is enable/<br>Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt<br>0: LSE ready interrupt<br>0: LSE ready interrupt<br>0: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt is enabled.<br>1: LSE ready interrupt is enabled.<br>1: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |           |    | 1: HSE ready interrupt is enabled.                                     |
| Bit 9LSESTBLIErw<br>aLSE ready interrupt is disabled.<br>1: HSI ready interrupt is enabled.<br>Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt is disabled.<br>1: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErw<br>aLSI ready interrupt enable<br>Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt<br>0: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErw<br>aLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt is disabled.<br>1: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.<br>1: Clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Bit 10  | HSISTBLIE | rw | HSI ready interrupt enable                                             |
| Image: Bit 9LSESTBLIErwLSE ready interrupt is disabled.<br>1: HSI ready interrupt is enabled.<br>Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt<br>0: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt is enabled.<br>1: LSE ready interrupt is enabled.<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt<br>0: LSI ready interrupt is enabled.<br>1: LSI ready interrupt is enabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt fiag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt fiag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |           |    | Set and cleared by software to enable/disable internal 8 MHz RC        |
| Image: Bit 9LSESTBLIErwLSE ready interrupt is enabled.<br>Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt<br>0: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt is enabled.<br>1: LSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt<br>0: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |           |    | oscillator ready interrupt                                             |
| Bit 9LSESTBLIErwLSE ready interrupt enable<br>Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt<br>0: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt is disabled.<br>1: LSE ready interrupt enableBit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt<br>0: LSI ready interrupt<br>0: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |           |    | 0: HSI ready interrupt is disabled.                                    |
| Bit 9Set and cleared by software to enable/disable external 32 kHz RC<br>oscillator ready interrupt<br>0: LSE ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interruptBit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |           |    | 1: HSI ready interrupt is enabled.                                     |
| Bit 8LSISTBLIErwLSI ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interruptBit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by software to prove by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5I-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Bit 9   | LSESTBLIE | rw | LSE ready interrupt enable                                             |
| Bit 8LSISTBLIErwLSI ready interrupt is disabled.<br>1: LSE ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt<br>0: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |           |    | Set and cleared by software to enable/disable external 32 kHz RC       |
| Image: Bit 8LSISTBLIErwLSI ready interrupt is enabled.Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt<br>0: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure. 1: Clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |           |    | oscillator ready interrupt                                             |
| Bit 8LSISTBLIErwLSI ready interrupt enable<br>Set and cleared by software to enable/disable internal 40 kHz RC<br>oscillator ready interrupt<br>0: LSI ready interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |           |    | 0: LSE ready interrupt is disabled.                                    |
| Bit 6CFDFrClock Failure Detection interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |           |    | 1: LSE ready interrupt is enabled.                                     |
| Bit 7CFDFrClock Failure Detection interrupt is disabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Bit 8   | LSISTBLIE | rw | LSI ready interrupt enable                                             |
| Bit 7CFDFrClock Failure Detection interrupt is enabled.<br>1: LSI ready interrupt is enabled.Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |           |    | Set and cleared by software to enable/disable internal 40 kHz RC       |
| Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure. 1: Clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |           |    | oscillator ready interrupt                                             |
| Bit 7CFDFrClock Failure Detection interrupt flag<br>Set by hardware when a failure is detected in the external 4~16<br>MHz oscillator clock. It is cleared by setting the CFDFC bit.<br>0: No clock security system interrupt is caused by HSE clock<br>failure. 1: Clock security system interrupt is caused by HSE clock<br>failure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |           |    | 0: LSI ready interrupt is disabled.                                    |
| CFDFrClock Failure Detection interrupt flagSet by hardware when a failure is detected in the external 4~16MHz oscillator clock. It is cleared by setting the CFDFC bit.0: No clock security system interrupt is caused by HSE clockfailure. 1: Clock security system interrupt is caused by HSE clockfailure.Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flagSet by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |           |    | 1: LSI ready interrupt is enabled.                                     |
| Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit 7   | CFDF      | r  | Clock Failure Detection interrupt flag                                 |
| Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |           |    | Set by hardware when a failure is detected in the external $4{\sim}16$ |
| Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLLSTBLFPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |         |           |    | MHz oscillator clock. It is cleared by setting the CFDFC bit.          |
| Bit 6:5-Reserved. Always read as 0.Bit 4PLLSTBLFrPLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |           |    | 0: No clock security system interrupt is caused by HSE clock           |
| Bit 6:5       -       Reserved. Always read as 0.         Bit 4       PLLSTBLF       r       PLL ready interrupt flag         Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |           |    | failure. 1: Clock security system interrupt is caused by HSE clock     |
| Bit 4       PLLSTBLF       r       PLL ready interrupt flag         Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |           |    | failure.                                                               |
| PLLSTBLF r PLL ready interrupt flag<br>Set by hardware when the PLL is stable and the LLSTBLIE bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Bit 6:5 |           | -  | Reserved. Always read as 0.                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Bit 4   | PLLSTBLF  | r  | PLL ready interrupt flag                                               |
| sot. It is cleared by setting the PLISTRIEC bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |           |    | Set by hardware when the PLL is stable and the LLSTBLIE bit is         |
| set. It is cleared by setting the FLLSTDLIC bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |           |    | set. It is cleared by setting the PLLSTBLFC bit.                       |



|       |          | 1 |                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|----------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |   | 0: No clock ready interrupt is caused by PLL lock. 1: Clock ready                                                                                                                                                                                                                                                                                                                       |
|       |          |   | interrupt is caused by PLL lock.                                                                                                                                                                                                                                                                                                                                                        |
| Bit 3 | HSESTBLF | r | <ul> <li>HSE ready interrupt flag</li> <li>Set by hardware when external low-speed clock is stable and the</li> <li>HSESTBLIE bit is set. It is cleared by setting the HSESTBLFC bit.</li> <li>0: No clock ready interrupt is caused by the external 4~16 MHz</li> <li>oscillator.</li> <li>1: Clock ready interrupt is caused by the external 4~16 MHz</li> <li>oscillator.</li> </ul> |
| Bit 2 | HSISTBLF | r | <ul> <li>HSI ready interrupt flag</li> <li>Set by hardware when internal high-speed clock is stable and the</li> <li>HSISTBLIE bit is set. It is cleared by setting the HSISTBLFC bit.</li> <li>0: No clock ready interrupt is caused by the internal 8 MHz</li> <li>oscillator.</li> <li>1: Clock ready interrupt is caused by the internal 8 MHz</li> <li>oscillator.</li> </ul>      |
| Bit 1 | LSESTBLF | r | LSE ready interrupt flag<br>Set by hardware when external low-speed clock is stable and the<br>LSESTBLIE bit is set. It is cleared by setting the LSESTBLFC bit.<br>0: No clock ready interrupt is caused by the external 32 kHz<br>oscillator. 1: Clock ready interrupt is caused by the external 32<br>kHz oscillator.                                                                |
| Bit 0 | LSISTBLF | r | LSI ready interrupt flag<br>Set by hardware when internal low-speed clock is stable and the<br>LSISTBLIE bit is set. It is cleared by setting the LSISTBLFC bit.<br>0: No clock ready interrupt is caused by the internal 40 kHz<br>oscillator.<br>1: Clock ready interrupt is caused by the internal 40 kHz<br>oscillator.                                                             |



# 3.3.4 APB2 Peripheral Reset Register (RCC\_APB2RST)

Address offset: 0x0C

Reset value: 0x0000 0000

Access: No wait state. Word, half-word, and byte access.

| Bit       | Name     | Туре | Description                                                                               |  |
|-----------|----------|------|-------------------------------------------------------------------------------------------|--|
| Bit 31:27 | -        | -    | Reserved. Always set to 0.                                                                |  |
| Bit 26    | UART8RST | rw   | UART8 reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset UART8             |  |
| Bit 25    | UART7RST | rw   | UART7 reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset UART7             |  |
| Bit 24    | UART6RST | rw   | UART6 reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset UART6             |  |
| Bit 23:22 | -        | -    | Reserved. Always set to 0.                                                                |  |
| Bit 21    | TMR11RST | rw   | TMR11 timer reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset TMR11 timer |  |
| Bit 20    | TMR10RST | rw   | TMR10 timer reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset TMR10 timer |  |
| Bit 19    | TMR9RST  | rw   | TMR9 timer reset                                                                          |  |



| 0: No effect                                             | 1 |
|----------------------------------------------------------|---|
|                                                          |   |
| 1: Reset TMR9 timer                                      |   |
| Bit 18:15 Reserved. Always set to 0.                     |   |
| USART1 reset                                             |   |
| Set and cleared by software.                             |   |
| Bit 14 USART1RST rw 0: No effect                         |   |
| 1: Reset USART1                                          |   |
| TMR 8 timer reset                                        |   |
| Bit 13 TMR8RST rw                                        |   |
| Bit 13 TMR8RST rw 0: No effect                           |   |
| 1: Reset TMR 8 timer                                     |   |
| SPI 1 reset                                              |   |
| Set and cleared by software.                             |   |
| Bit 12 SPI1RST rw 0: No effect                           |   |
| 1: Reset SPI1                                            |   |
| TMR1 timer reset                                         |   |
| Bit 11     TMR1RST     rw   Set and cleared by software. |   |
| Bit 11 TMR1RST rw 0: No effect                           |   |
| 1: Reset TMR 1 timer                                     |   |
| Bit 10 - Reserved. Always set to 0.                      |   |
| ADC1 interface reset                                     |   |
| Set and cleared by software.                             |   |
| Bit 9 ADC1RST rw 0: No effect                            |   |
| 1: Reset ADC1 interface                                  |   |
| Bit 8:7 - Reserved. Always read as 0.                    |   |
| IO port E reset                                          |   |
| Bit 6 GPIOERST rw Set and cleared by software.           |   |
| 0: No effect                                             |   |



|       |                |    | 1: Reset IO port E                  |
|-------|----------------|----|-------------------------------------|
|       |                |    | IO port D reset                     |
|       | Bit 5 GPIODRST |    | Set and cleared by software.        |
| Bit 5 |                | rw | 0: No effect                        |
|       |                |    | 1: Reset IO port D                  |
|       |                |    | IO port C reset                     |
|       |                |    | Set and cleared by software.        |
| Bit 4 | GPIOCRST       | rw | 0: No effect                        |
|       |                |    | 1: Reset IO port C                  |
|       |                |    | IO port B reset                     |
|       |                |    | Set and cleared by software.        |
| Bit 3 | GPIOBRST       | rw | 0: No effect                        |
|       |                |    | 1: Reset IO port B                  |
|       |                |    | IO port A reset                     |
|       |                |    | Set and cleared by software.        |
| Bit 2 | GPIOARST       | rw | 0: No effect                        |
|       |                |    | 1: Reset IO port A                  |
|       |                |    | EXTI reset                          |
|       |                |    | Set and cleared by software.        |
| Bit 1 | EXTIRST        | w  | 0: No effect                        |
|       |                |    | 1: Reset EXTI                       |
|       |                |    | Note: Write-only; always read as 0. |
|       |                | rw | Alternate function I/O reset        |
| Bit 0 | Bit 0 AFIORST  |    | Set and cleared by software.        |
|       |                |    | 0: No effect                        |
|       |                |    | 1: Reset alternate function         |

# 3.3.5 APB1 Peripheral Reset Register (RCC\_APB1RST)

Address offset: 0x10



| Bit       | Name       | Туре | Description                                                                                         |  |
|-----------|------------|------|-----------------------------------------------------------------------------------------------------|--|
| Bit 31:29 | -          | -    | Reserved. Always read as 0.                                                                         |  |
| Bit 28    | PWRRST     | rw   | Power interface reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset power interface   |  |
| Bit 27    | BKPRST     | rw   | Backup interface reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset backup interface |  |
| Bit 26    | I2C3RST    | rw   | I2C3 reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset CAN2                         |  |
| Bit 25    | CAN1RST    | rw   | CAN reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset CAN1                          |  |
| Bit 24    | -          | -    | Reserved. Always read as 0.                                                                         |  |
| Bit 23    | USBRST     | rw   | USB reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset USB                           |  |
| Bit 22    | I2C2RST rw |      | I2C 2 reset<br>Set and cleared by software.<br>0: No effect<br>1: Reset I2C 2                       |  |



|        |           |    | I2C 1 reset                  |
|--------|-----------|----|------------------------------|
|        |           |    | Set and cleared by software. |
| Bit 21 | I2C1RST   | rw | 0: No effect                 |
|        |           |    | 1: Reset I2C 1               |
|        |           |    | UART 5 reset                 |
|        |           |    | Set and cleared by software. |
| Bit 20 | UART5RST  | rw | 0: No effect                 |
|        |           |    | 1: Reset UART5               |
|        |           |    |                              |
|        |           |    | UART 4 reset                 |
| Bit 19 | UART4RST  | rw | Set and cleared by software. |
|        |           |    | 0: No effect                 |
|        |           |    | 1: Reset UART 4              |
|        |           |    | USART 3 reset                |
| Bit 18 | USART3RST | rw | Set and cleared by software. |
| Die 10 |           |    | 0: No effect                 |
|        |           |    | 1: Reset USART 3             |
|        |           | rw | USART 2 reset                |
|        | USART2RST |    | Set and cleared by software. |
| Bit 17 | USARIZRSI |    | 0: No effect                 |
|        |           |    | 1: Reset USART2              |
|        |           |    | SPI 4 reset                  |
|        |           | rw | Set and cleared by software. |
| Bit 16 | SPI4RST   |    | 0: No effect                 |
|        |           |    | 1: Reset SPI 4               |
|        |           |    | SPI 3 reset                  |
|        | SPI3RST   | rw | Set and cleared by software. |
| Bit 15 |           |    | 0: No effect                 |
|        |           |    | 1: Reset SPI 3               |
|        |           |    | SPI 2 reset                  |
| Bit 14 | SPI2RST   | rw | Set and cleared by software. |



| 0: No effect         1: Reset SPI 2         Bit 13:12       -         Reserved. Always read as 0.         Window watchdog reset |  |
|---------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 13:12 Reserved. Always read as 0.                                                                                           |  |
|                                                                                                                                 |  |
| Window watchdog reset                                                                                                           |  |
|                                                                                                                                 |  |
| Bit 11 WWDGRST rw Set and cleared by software.                                                                                  |  |
| 0: No effect                                                                                                                    |  |
| 1: Reset Window watchdog                                                                                                        |  |
| Bit 10:9 - Reserved. Always read as 0.                                                                                          |  |
| Timer 14 reset                                                                                                                  |  |
| Bit 8     TMR14RST     rw   Set and cleared by software.                                                                        |  |
| Bit 8 TMR14RST rw<br>0: No effect                                                                                               |  |
| 1: Reset TMR 14 timer                                                                                                           |  |
| Timer 13 reset                                                                                                                  |  |
| Bit 7     TMR13RST     rw   Set and cleared by software.                                                                        |  |
| Bit 7 TMR13RST rw 0: No effect                                                                                                  |  |
| 1: Reset TMR 13 timer                                                                                                           |  |
| Timer 12 reset                                                                                                                  |  |
| Bit 6     TMR12RST     rw   Set and cleared by software.                                                                        |  |
| Bit 6 IMR12RS1 rw<br>0: No effect                                                                                               |  |
| 1: Reset TMR 12 timer                                                                                                           |  |
| Timer 7 reset                                                                                                                   |  |
| Set and cleared by software.                                                                                                    |  |
| Bit 5 TMR7RST rw<br>0: No effect                                                                                                |  |
| 1: Reset TMR 7 timer                                                                                                            |  |
| Timer 6 reset                                                                                                                   |  |
| Set and cleared by software.                                                                                                    |  |
| Bit 4 TMR6RST rw<br>0: No effect                                                                                                |  |
| 1: Reset TMR 6 timer                                                                                                            |  |



|       |         |      | Timer 5 reset                |
|-------|---------|------|------------------------------|
|       | TMR5RST | rw   | Set and cleared by software. |
| Bit 3 |         |      | 0: No effect                 |
|       |         |      | 1: Reset TMR 5 timer         |
|       |         |      | Timer 4 reset                |
| Bit 2 | TMR4RST | rw   | Set and cleared by software. |
| BIT 2 |         | 1 00 | 0: No effect                 |
|       |         |      | 1: Reset TMR 4 timer         |
|       | TMR3RST | rw   | Timer 3 reset                |
| Bit 1 |         |      | Set and cleared by software. |
|       | THRONOT |      | 0: No effect                 |
|       |         |      | 1: Reset TMR 3 timer         |
|       |         |      | Timer 2 reset                |
| Bit 0 | TMR2RST | rw   | Set and cleared by software. |
|       |         |      | 0: No effect                 |
|       |         |      | 1: Reset TMR 2 timer         |

# 3.3.6 AHB Peripheral Clock Enable Register (RCC\_AHBEN)

Address offset: 0x14

Reset value: 0x0000 0014

Access: No wait state. Word, half-word, and byte access.

Note: If peripheral clock is not enabled, the software will not be able to read the value of peripheral register, and the returned value is always 0x0.

| Bit       | Name | Туре | Description                 |
|-----------|------|------|-----------------------------|
| Bit 31:12 | -    | -    | Reserved. Always read as 0. |



| Bit 11:10 | -       | -  | Reserved                                                      |
|-----------|---------|----|---------------------------------------------------------------|
| Bit 9     | -       | -  | Reserved. Always read as 0.                                   |
|           |         |    | XMC clock enable                                              |
| Bit 8     | VMCEN   |    | Set and cleared by software.                                  |
| Die O     | XMCEN   | rw | 0: XMC clock is disabled.                                     |
|           |         |    | 1: XMC clock is enabled.                                      |
| Bit 7     |         | -  | Reserved. Always read as 0.                                   |
|           |         |    | CRC clock enable                                              |
|           |         |    | Set and cleared by software.                                  |
| Bit 6     | CCE     | rw | 0: CRC clock is disabled.                                     |
|           |         |    | 1: CRC clock is enabled.                                      |
| Bit 5     | -       | -  | Reserved. Always read as 0.                                   |
|           |         |    | FLITF clock enable                                            |
|           |         | rw | Set and cleared by software to enable/ disable FLITF clock in |
| Bit 4     | FLASHEN |    | Sleep mode.                                                   |
|           |         |    | 0: FLITF clock is disabled in Sleep mode.                     |
|           |         |    | 1: FLITF clock is enabled in Sleep mode.                      |
| Bit 3     | -       | -  | Reserved. Always read as 0.                                   |
|           | SRAMEN  | rw | SRAM interface clock enable                                   |
|           |         |    | Set and cleared by software to enable/ disable SRAM clock in  |
| Bit 2     |         |    | Sleep mode.                                                   |
|           |         |    | 0: SRAM clock is disabled in Sleep mode.                      |
|           |         |    | 1: SRAM clock is enabled in Sleep mode.                       |
|           |         |    | DMA2 clock enable                                             |
|           | DMA2EN  | rw | Set and cleared by software.                                  |
| Bit 1     |         |    | 0: DMA2 clock is disabled.                                    |
|           |         |    | 1: DMA2 clock is enabled.                                     |
|           |         |    | DMA1 clock enable                                             |
| Bit 0     | DMA1EN  | rw | Set and cleared by software.                                  |
| L         | 1       | I  | 1                                                             |



|  | 0: DMA1 clock is disabled. |
|--|----------------------------|
|  | 1: DMA1 clock is enabled.  |

# 3.3.7 APB2 Peripheral Clock Enable Register (RCC\_APB2EN)

Address offset: 0x18

Reset value: 0x0000 0000

Access: Word, half-word, and byte access.

Usually no waiting state, but if peripherals on APB2 bus are accessed, waiting states will be inserted until the end of APB2 peripheral access.

Note: If peripheral clock is not enabled, the software will not be able to read the value of peripheral register, and the returned value is always 0x0.

| Bit       | Name      | Туре      | Description                  |
|-----------|-----------|-----------|------------------------------|
| Bit 31:27 | -         | -         | Reserved. Always read as 0.  |
|           |           |           | UART8 clock enable           |
|           | UART8EN   | rw        | Set and cleared by software. |
| Bit 26    | UARTOLN   | 1 VV      | 0: UART8 clock is disabled.  |
|           |           |           | 1: UART8 clock is enabled.   |
|           |           |           | UART7 clock enable           |
| D:1 25    | UART7EN   | rw        | Set and cleared by software. |
| Bit 25    |           |           | 0: UART7 clock is disabled.  |
|           |           |           | 1: UART7 clock is enabled.   |
|           |           | ART6EN rw | USART6 clock enable          |
| D:h 24    |           |           | Set and cleared by software. |
| Bit 24    | USARTOLIN |           | 0: USART6 clock is disabled. |
|           |           |           | 1: USART6 clock is enabled.  |
| Bit 23    | -         | -         | Reserved                     |
| Bit 22    | -         | -         | Reserved                     |



| Bit 21     TMR11EN     rw     Set and cleared by software.<br>0: TMR11 timer clock is disabled.<br>1: TMR11 timer clock is disabled.       Bit 20     TMR10EN     rw     Set and cleared by software.<br>0: TMR10 timer clock is disabled.<br>1: TMR9EN       Bit 19     TMR9EN     rw     Set and cleared by software.<br>0: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is enabled.<br>1: TMR9 timer clock is enabled.       Bit 18:16     -     -     Reserved. Always read as 0.       Bit 18:16     -     -     Reserved.       Bit 18:16     -     Reserved.     USART1 clock enabled.       Bit 13     -     -     Reserved.       Bit 14     USART1EN     rw     Set and cleared by software.<br>0: USART1 clock is disabled.<br>1: USART1 clock is disabled.<br>1: USART1 clock is disabled.       Bit 13     TMRBEN     rw     Set and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is disabled.       Bit 12     SP11EN     rw     Set and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is disabled.       Bit 11     TMR1EN     rw     Set and cleared by software.<br>0: SP11 clock is disabled.<br>1: SP11 clock is disabled.       Bit 11     TMR1EN     rw     Set and cleared by software.<br>0: SP11 clock is disabled.       Bit 11     TM |                 |           |      |                                   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------|------|-----------------------------------|
| Bit 21     TMR11EN     rw     0: TMR11 timer clock is disabled.       Bit 20     TMR10EN     rw     Set and cleared by software.       Bit 20     TMR10EN     rw     Set and cleared by software.       Bit 19     TMR9EN     rw     Set and cleared by software.       Bit 19     TMR9EN     rw     Set and cleared by software.       Bit 19     TMR9EN     rw     Set and cleared by software.       Bit 19     TMR9EN     rw     Set and cleared by software.       Bit 18:16     -     -     Reserved. Always read as 0.       Bit 18:16     -     -     Reserved       Bit 13     rw     rw     Set and cleared by software.       Bit 14     USART1EN     rw     USART1 clock enable       Bit 14     USART1EN     rw     Set and cleared by software.       Bit 13     rw     rw     Set and cleared by software.       Bit 13     rw     rw     Set and cleared by software.       Bit 13     SPI11 clock is disabled.     1: USART1 clock is disabled.       Bit 12     SPI11EN     rw     Set and cleared by software.       Bit 12     SPI11EN     rw     Set and cleared by software.       Bit 11     TMR18     rw     Set and cleared by software.       Bit 11     TMR18 <td></td> <td></td> <td></td> <td>Timer 11 clock enable</td>                                                                                                                                                                                                                                                                                |                 |           |      | Timer 11 clock enable             |
| Bit 12       TMR10EN       rw       0: TMR11 timer clock is disabled.         Bit 20       TMR10EN       rw       Set and cleared by software.         0: TMR10 timer clock is disabled.       1: TMR10 timer clock is disabled.         Bit 19       TMR9EN       rw       Set and cleared by software.         0: TMR10 timer clock is disabled.       1: TMR10 timer clock is disabled.         Bit 19       TMR9EN       rw       Set and cleared by software.         0: TMR9 timer clock is disabled.       1: TMR9 timer clock is disabled.         Bit 18:16       -       -       Reserved.         Bit 18:16       -       -       Reserved.         Bit 15       -       -       Reserved.         Bit 15       -       -       Reserved.         Bit 14       USART1EN       rw       Set and cleared by software.         0: USART1 clock enable       Set and cleared by software.       0: USART1 clock is disabled.         1: USART1 clock is disabled.       1: USART1 clock is disabled.       1: USART1 clock is disabled.         Bit 13       TMR8EN       rw       Set and cleared by software.       0: TMR8 timer clock is disabled.         Bit 12       SPI11EN       rw       Set and cleared by software.       0: SPI1 clock enable                                                                                                                                                                                                                                                                    | Rit 21          |           | rw   | Set and cleared by software.      |
| Bit 20TMR10ENrwTimer 10 clock enable<br>Set and cleared by software.<br>0: TMR10 timer clock is disabled.<br>1: TMR10 timer clock is enabled.Bit 19TMR9ENrwTimer 9 clock enable<br>Set and cleared by software.<br>0: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is enabled.Bit 19TMR9ENrwSet and cleared by software.<br>0: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is enabled.Bit 15Reserved. Always read as 0.Bit 15Reserved.Bit 14USART1ENrwUSART1 clock enable<br>Set and cleared by software.<br>0: USART1 clock is disabled.<br>1: TMR8 timer clock is disabled.<br>1: SPI1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is enabled.Bit 11TMR1ENrwTimer 1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is enabled.Bit 11TMR1ENrwSet and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is enabled.                          |                 | THREEN    |      | 0: TMR11 timer clock is disabled. |
| Bit 20TMR10ENrwSet and cleared by software.<br>0: TMR10 timer clock is disabled.<br>1: TMR10 timer clock is enabled.<br>1: TMR10 timer clock is enabled.Bit 19TMR9ENrwSet and cleared by software.<br>0: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is enabled.Bit 18:16Reserved. Always read as 0.Bit 15Reserved.Bit 16Reserved.Bit 17Reserved.Bit 18Reserved.Bit 14USART1ENrwSet and cleared by software.<br>0: USART1 clock is disabled.<br>1: USART1 clock is disabled.<br>1: USART1 clock is enabled.<br>1: USART1 clock is disabled.<br>1: USART1 clock is enabled.<br>1: USART1 clock is disabled.<br>1: USART1 clock is disabled.<br>1: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is enabled.<br>1: SPI1 clock is enabled.<br>1: SPI1 clock is enabled.<br>1: SPI1 clock is enabled.Bit 11TMR1ENrwTimer 1 clock enable<br>Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                 |                 |           |      | 1: TMR11 timer clock is enabled.  |
| Bit 20     TMR10EN     rw     0: TMR10 timer clock is disabled.       Bit 19     TMR9EN     rw     3 Set and cleared by software.       Bit 19     TMR9EN     rw     Set and cleared by software.       Bit 19     -     -     Reserved. Always read as 0.       Bit 15     -     -     Reserved.       Bit 14     USART1EN     rw     USART1 clock enable       Bit 14     USART1EN     rw     Set and cleared by software.       0: USART1 clock is disabled.     0: USART1 clock is disabled.       Bit 14     USART1EN     rw     Set and cleared by software.       Bit 13     TMR8EN     rw     Set and cleared by software.       Bit 13     TMR8EN     rw     Set and cleared by software.       Bit 13     TMR8EN     rw     Set and cleared by software.       Bit 13     TMR8EN     rw     Set and cleared by software.       Bit 12     SPI1EN     rw     Set and cleared by software.       Bit 12     SPI1EN     rw     Set and cleared by software.       Bit 11     TMR1EN     rw     Set and cleared by software.       Bit 11     TMR1EN     rw     Set and cleared by software.       Bit 11     TMR1EN     rw     Set and cleared by software.       Bit 11     TMR1EN                                                                                                                                                                                                                                                                                                                                           |                 |           |      | Timer 10 clock enable             |
| Die LoO: TMR10 timer clock is disabled.<br>1: TMR10 timer clock is enabled.Bit 19TMR9ENrwTimer 9 clock enable<br>Set and cleared by software.<br>0: TMR9 timer clock is enabled.<br>1: TMR9 timer clock is enabled.Bit 18:16Reserved. Always read as 0.Bit 15ReservedBit 15ReservedBit 14USART1ENrwSet and cleared by software.<br>0: USART1 clock enable<br>Set and cleared by software.<br>0: USART1 clock is disabled.<br>1: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is enabled.<br>1: SPI1 clock is enabled.Bit 11TMR1ENrwSet and cleared by software.<br>0: SPI1 clock is enabled.<br>1: SPI1 clock is enabled.Bit 11TMR1ENrwSet and cleared by software.<br>0: SPI1 clock is enabled.Bit 11TMR1ENrwSet and cleared by software.                                                                                                                                                        | D:+ 20          |           | r\\\ | Set and cleared by software.      |
| Bit 19TMR9ENrwTimer 9 clock enable<br>Set and cleared by software.<br>0: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is enabled.Bit 18:16Reserved. Always read as 0.Bit 15Reserved.Bit 15Reserved.Bit 14USART1ENrwUSART1 clock enable<br>Set and cleared by software.<br>0: USART1 clock is disabled.<br>1: USART1 clock is disabled.<br>1: USART1 clock is enabled.Bit 13TMR8ENrwSet and cleared by software.<br>0: USART1 clock is disabled.<br>1: USART1 clock is enabled.Bit 13TMR8ENrwSet and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.Bit 11TMR1ENrwSet and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | DIL 20          | TRICIOLIN |      | 0: TMR10 timer clock is disabled. |
| Bit 19TMR9ENrwSet and cleared by software.<br>0: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is enabled.Bit 18:16Reserved. Always read as 0.Bit 15Reserved. Always read as 0.Bit 15ReservedBit 14USART1ENrwUSART1 clock enable<br>Set and cleared by software.<br>0: USART1 clock is disabled.<br>1: USART1 clock is disabled.<br>1: USART1 clock is enabled.Bit 13TMR8ENrwSet and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>Set and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>Set and cleared by software.Bit 11TMR1ENrwSet and cleared by software.<br>Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |           |      | 1: TMR10 timer clock is enabled.  |
| Bit 19TMR9ENrw0: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is enabled.Bit 18:16Reserved. Always read as 0.Bit 15Reserved.Bit 15ReservedBit 15ReservedBit 14USART1ENrwSet and cleared by software.<br>0: USART1 clock is disabled.<br>1: USART1 clock is disabled.<br>1: USART1 clock is enabled.<br>1: TIMR8 timer clock is disabled.<br>1: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.<br>1: SPI1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is enabled.<br>1: SPI1 clock is enabled.Bit 11TMR1ENrwSet and cleared by software.<br>0: SPI1 clock is enabled.<br>1: SPI1 clock is enabled.                                                                                                                                                                                                                                                                                                                                                                                              |                 |           |      | Timer 9 clock enable              |
| Dit 130: TMR9 timer clock is disabled.<br>1: TMR9 timer clock is enabled.Bit 18:16Bit 15Reserved. Always read as 0.Bit 15ReservedUSART1-Bit 14USART1ENrwSet and cleared by software.<br>0: USART1 clock is disabled.<br>1: USART1 clock is enabled.<br>1: USART1 clock is enabled.Bit 13TMR8ENrwSet and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwBit 12SPI1ENrwBit 11TMR1ENrwSet and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is enabled.Bit 11TMR1ENrwSet and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Dit 10          | TMRGEN    | r\\\ | Set and cleared by software.      |
| Bit 18:16Reserved. Always read as 0.Bit 15ReservedBit 15ReservedBit 14USART1ENrwUSART1 clock enable<br>Set and cleared by software.<br>0: USART1 clock is disabled.<br>1: USART1 clock is enabled.Bit 13TMR8ENrwTimer 8 clock enable<br>Set and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: TMR8 timer clock is enabled.<br>1: TMR8 timer clock is enabled.<br>1: TMR8 timer clock is enabled.<br>1: SPI 1 clock enable<br>Set and cleared by software.<br>0: SPI 1 clock is disabled.<br>1: SPI 1 clock is disabled.Bit 11TMR1ENrwSet and cleared by software.<br>Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                              | BIT 19          | THRUEN    |      | 0: TMR9 timer clock is disabled.  |
| Bit 15ReservedBit 15ReservedBit 14USART1ENrwUSART1 clock enable<br>Set and cleared by software.<br>0: USART1 clock is disabled.<br>1: USART1 clock is enabled.<br>1: USART1 clock is enabled.Bit 13TMR8ENrwTimer 8 clock enable<br>Set and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: SPI 1 clock enable<br>Set and cleared by software.<br>0: SPI 1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is enabled.Bit 11TMR1ENrwSet and cleared by software.<br>Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |           |      | 1: TMR9 timer clock is enabled.   |
| Bit 13       USART1EN       rw       USART1 clock enable         Bit 14       USART1EN       rw       USART1 clock enable         Set and cleared by software.       0: USART1 clock is disabled.         0: USART1 clock is enabled.       1: USART1 clock is enabled.         Bit 13       TMR8EN       rw       Set and cleared by software.         0: TMR8 timer clock is disabled.       1: TMR8 timer clock is disabled.         1: TMR8 timer clock is enabled.       1: TMR8 timer clock is enabled.         Bit 12       SPI1EN       rw       SPI 1 clock enable         Bit 12       SPI1EN       rw       Set and cleared by software.         0: SPI1 clock is enabled.       1: TMR8 timer clock is enabled.         Bit 11       TMR1EN       rw       Set and cleared by software.         0: SPI1 clock is enabled.       1: SPI1 clock is enabled.         1: SPI1 clock is enabled.       1: SPI1 clock is enabled.         Bit 11       TMR1EN       rw       Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Bit 18:16       | -         | -    | Reserved. Always read as 0.       |
| Bit 14USART1ENrwSet and cleared by software.<br>0: USART1 clock is disabled.<br>1: USART1 clock is enabled.Bit 13TMR8ENrwTimer 8 clock enable<br>Set and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: SPI 1 clock enable<br>Set and cleared by software.<br>0: SPI 1 clock enabled.<br>1: SPI clock is disabled.<br>1: SPI 1 clock is disabled.Bit 11TMR1ENrwSet and cleared by software.                                                                                                                                                                                                                                               | Bit 15          | -         | -    | Reserved                          |
| Bit 14USART1ENrw0: USART1 clock is disabled.<br>1: USART1 clock is enabled.Bit 13TMR8ENrwTimer 8 clock enable<br>Set and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.Bit 11TMR1ENrwTimer 1 clock enable<br>Set and cleared by software.Bit 11TMR1ENrwSet and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                 |           |      | USART1 clock enable               |
| Dit 11ConstructionO: USART1 clock is disabled.<br>1: USART1 clock is enabled.Bit 13TMR8ENrwTimer 8 clock enable<br>Set and cleared by software.<br>O: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>O: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.Bit 11TMR1ENrwSet and cleared by software.<br>Set and cleared by software.<br>Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                 |           |      | Set and cleared by software.      |
| Bit 13TMR8ENrwTimer 8 clock enable<br>Set and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is enabled.Bit 11TMR1ENrwTimer 1 clock enable<br>Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Bit 14          | USARTILN  | 1 VV | 0: USART1 clock is disabled.      |
| Bit 13TMR8ENrwSet and cleared by software.<br>0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is disabled.<br>1: SPI1 clock is enabled.Bit 11TMR1ENrwTimer 1 clock enable<br>Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |           |      | 1: USART1 clock is enabled.       |
| Bit 13TMR8ENrw0: TMR8 timer clock is disabled.<br>1: TMR8 timer clock is enabled.Bit 12SPI1ENrwSPI 1 clock enable<br>Set and cleared by software.<br>0: SPI1 clock is disabled.<br>1: SPI1 clock is enabled.<br>1: SPI1 clock is enabled.Bit 11TMR1ENrwTimer 1 clock enable<br>Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                 |           |      | Timer 8 clock enable              |
| Bit 13       0: TMR8 timer clock is disabled.         1: TMR8 timer clock is enabled.         Bit 12       SPI1EN         rw       Set and cleared by software.         0: SPI1 clock is disabled.         1: SPI1 clock is enabled.         Set and cleared by software.         0: SPI1 clock is disabled.         1: SPI1 clock is enabled.         Timer 1 clock enable         Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <b>D</b> 11 4 D | TMDOEN    | rw   | Set and cleared by software.      |
| Bit 12       SPI1EN       rw       SPI 1 clock enable         Set and cleared by software.       Set and cleared by software.         0: SPI1 clock is disabled.       1: SPI1 clock is enabled.         1: SPI1 clock is enabled.       1: SPI1 clock is enabled.         Bit 11       TMR1EN       rw       Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | BIT 13          | IMROLIN   |      | 0: TMR8 timer clock is disabled.  |
| Bit 12       SPI1EN       rw       Set and cleared by software.         0: SPI1 clock is disabled.       0: SPI1 clock is enabled.         1: SPI1 clock is enabled.       1: SPI1 clock enable         Bit 11       TMR1EN       rw       Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |           |      | 1: TMR8 timer clock is enabled.   |
| Bit 12       SPI1EN       rw       0: SPI1 clock is disabled.         1: SPI1 clock is enabled.       1: SPI1 clock is enabled.         Bit 11       TMR1EN       rw       Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |           |      | SPI 1 clock enable                |
| Dit 12       0: SPI1 clock is disabled.         1: SPI1 clock is enabled.         Bit 11       TMR1EN         rw       Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Bi+ 10          | SPI1 FN   | rw   | Set and cleared by software.      |
| Bit 11     TMR1EN     rw     Timer 1 clock enable       Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 | JFIILIN   |      | 0: SPI1 clock is disabled.        |
| Bit 11 TMR1EN rw Set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |           |      | 1: SPI1 clock is enabled.         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |           |      | Timer 1 clock enable              |
| 0: TMR1 timer clock is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Bit 11          | TMR1EN    | rw   | Set and cleared by software.      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |           |      | 0: TMR1 timer clock is disabled.  |



|         |         |      | 1: TMR1 timer clock is enabled.      |
|---------|---------|------|--------------------------------------|
| Bit 10  | -       | -    | Reserved                             |
|         |         |      | ADC 1 interface clock enable         |
|         |         |      | Set and cleared by software.         |
| Bit 9   | ADC1EN  | rw   | 0: ADC1 interface clock is disabled. |
|         |         |      | 1: ADC1 interface clock is enabled.  |
| Bit 8:7 | -       | -    | Reserved. Always read as 0.          |
|         |         |      | I/O port E clock enable              |
| Dit C   | CDIOFEN |      | Set and cleared by software.         |
| Bit 6   | GPIOEEN | rw   | 0: Port E clock is disabled.         |
|         |         |      | 1: Port E clock is enabled.          |
|         |         |      | I/O port D clock enable              |
|         | GPIODEN | rw   | Set and cleared by software.         |
| Bit 5   | GIIODEN | 1 00 | 0: Port D clock is disabled.         |
|         |         |      | 1: Port D clock is enabled.          |
|         |         |      | I/O port C clock enable              |
|         | GPIOCEN | rw   | Set and cleared by software.         |
| Bit 4   | GIIOCEN | 1 00 | 0: Port C clock is disabled.         |
|         |         |      | 1: Port C clock is enabled.          |
|         |         |      | I/O port B clock enable              |
|         | GPIOBEN | rw   | Set and cleared by software.         |
| Bit 3   | GFIODEN | 1 00 | 0: Port B clock is disabled.         |
|         |         |      | 1: Port B clock is enabled.          |
|         |         |      | I/O port A clock enable              |
| Dit 0   | GPIOAEN | rw   | Set and cleared by software.         |
| Bit 2   |         |      | 0: Port A clock is disabled.         |
|         |         |      | 1: Port A clock is enabled.          |
| Bit 1   | -       | -    | Reserved. Always read as 0.          |
| Bit 0   | AFIOEN  | rw   | Alternate function I/O clock enable  |



|  | Set and cleared by software.             |
|--|------------------------------------------|
|  | 0: Alternate function clock is disabled. |
|  | 1: Alternate function clock is enabled.  |

# 3.3.8 APB1 Peripheral Clock Enable Register (RCC\_APB1EN)

Address offset: 0x1C

Reset value: 0x0000 0000

Access: Word, half-word, and byte access.

Usually no waiting state, but if peripherals on APB1 bus are accessed, waiting states will be inserted until the end of APB1 peripheral access.

Note: If peripheral clock is not enabled, the software will not be able to read the value of peripheral register, and the returned value is always 0x0.

| Bit       | Name   | Туре | Description                                                             |
|-----------|--------|------|-------------------------------------------------------------------------|
| Bit 31:30 | -      | -    | Reserved. Always read as 0.                                             |
| Bit 29    |        | -    | Reserved                                                                |
|           |        |      | Power interface clock enable                                            |
| Bit 28    | PWRFN  | rw   | Set and cleared by software.                                            |
| DIL 28    |        |      | 0: Power interface clock is disabled.                                   |
|           |        |      | 1: Power interface clock is enabled.                                    |
|           |        |      | Backup interface clock enable                                           |
| D:: 27    | BKPEN  | rw   | Set and cleared by software.                                            |
| Bit 27    |        |      | 0: Backup interface clock is disabled.                                  |
|           |        |      | 1: Backup interface clock is enabled.                                   |
| Bit 26    | I2C3EN | rw   | I2C 3 clock enable (I2C 3 clock enable) is set to '1' or cleared to '0' |



| 1      |          |     |                              |
|--------|----------|-----|------------------------------|
|        |          |     | by software                  |
|        |          |     | 0: I2C 3 clock is off.       |
|        |          |     | 1: I2C 3 clock is on.        |
|        |          |     | CAN1 clock enable            |
| Bit 25 | CAN1EN   | rw  | Set and cleared by software. |
| DIL 25 | CANTEN   |     | 0: CAN1 clock is disabled.   |
|        |          |     | 1: CAN1 clock is enabled.    |
| Bit 24 | -        | -   | Reserved. Always read as 0.  |
|        |          |     | USB clock enable             |
| Bit 23 | USBEN    | rw  | Set and cleared by software. |
|        |          |     | 0: USB clock is disabled.    |
|        |          |     | 1: USB clock is enabled.     |
|        |          |     | I2C 2 clock enable           |
| Bit 22 | I2C2EN   | rw  | Set and cleared by software. |
| DIL 22 | 1202210  | IVV | 0: I2C 2 clock is disabled.  |
|        |          |     | 1: I2C 2 clock is enabled.   |
|        |          |     | I2C 1 clock enable           |
| Bit 21 | I2C1EN   | rw  | Set and cleared by software. |
|        |          |     | 0: I2C 1 clock is disabled.  |
|        |          |     | 1: I2C 1 clock is enabled.   |
|        |          |     | UART 5 clock enable          |
|        |          |     | Set and cleared by software. |
| Bit 20 | UART5EN  | rw  | 0: UART5 clock is disabled.  |
|        |          |     | 1: UART5 clock is enabled.   |
|        |          |     | UART 4 clock enable          |
| Bit 19 | UART4EN  | rw  | Set and cleared by software. |
|        |          |     | 0: UART4 clock is disabled.  |
|        |          |     | 1: UART4 clock is enabled.   |
| Bit 18 | USART3EN | rw  | USART 3 clock enable         |
|        |          |     |                              |



|           |          | 1            |                                       |
|-----------|----------|--------------|---------------------------------------|
|           |          |              | Set and cleared by software.          |
|           |          |              | 0: USART3 clock is disabled.          |
|           |          |              | 1: USART3 clock is enabled.           |
|           |          |              | USART 2 clock enable                  |
| Ri+ 17    | USART2EN | rw           | Set and cleared by software.          |
| Bit 17    |          |              | 0: USART2 clock is disabled.          |
|           |          |              | 1: USART2 clock is enabled.           |
|           |          |              | SPI 4 clock enable                    |
|           | SPI4EN   | <b>F14</b> / | Set and cleared by software.          |
| Bit 16    |          | rw           | 0: SPI 4 clock is disabled.           |
|           |          |              | 1: SPI 4 clock is enabled.            |
|           |          |              | SPI 3 clock enable                    |
| Bit 15    | SPI3EN   | rw           | Set and cleared by software.          |
|           |          |              | 0: SPI 3 clock is disabled.           |
|           |          |              | 1: SPI 3 clock is enabled.            |
|           |          |              | SPI 2 clock enable                    |
| Bit 14    | SPI2EN   | rw           | Set and cleared by software.          |
|           |          |              | 0: SPI 2 clock is disabled.           |
|           |          |              | 1: SPI 2 clock is enabled.            |
| Bit 13:12 | -        | -            | Reserved. Always read as 0.           |
|           |          |              | Window watchdog clock enable          |
| Bit 11    | WWDGEN   | 5141         | Set and cleared by software.          |
|           |          | rw           | 0: Window watchdog clock is disabled. |
|           |          |              | 1: Window watchdog clock is enabled.  |
| Bit 10:9  | -        | -            | Reserved. Always read as 0.           |
|           |          |              | Timer 14 clock enable                 |
| Bit 8     | TMR14EN  | rw           | Set and cleared by software.          |
|           |          |              | 0: Timer 14 clock is disabled.        |
| L         | <u> </u> | <u> </u>     |                                       |



|       |         |      | 1: Timer 14 clock is enabled.  |
|-------|---------|------|--------------------------------|
|       |         |      | Timer 13 clock enable          |
|       |         |      |                                |
| Bit 7 | TMR13EN | rw   | Set and cleared by software.   |
|       |         |      | 0: Timer 13 clock is disabled. |
|       |         |      | 1: Timer 13 clock is enabled.  |
|       |         |      | Timer 12 clock enable          |
|       | TMR12EN | rw   | Set and cleared by software.   |
| Bit 6 | IMAIZEN | 1 00 | 0: Timer 12 clock is disabled. |
|       |         |      | 1: Timer 12 clock is enabled.  |
|       |         |      | Timer 7 clock enable           |
|       |         |      | Set and cleared by software.   |
| Bit 5 | TMR7EN  | rw   | 0: Timer 7 clock is disabled.  |
|       |         |      | 1: Timer 7 clock is enabled.   |
|       |         | rw   | Timer 6 clock enable           |
|       |         |      | Set and cleared by software.   |
| Bit 4 | TMR6EN  |      | 0: Timer 6 clock is disabled.  |
|       |         |      | 1: Timer 6 clock is enabled.   |
|       |         | rw   | Timer 5 clock enable           |
|       | TMR5EN  |      | Set and cleared by software.   |
| Bit 3 |         |      | 0: Timer 5 clock is disabled.  |
|       |         |      | 1: Timer 5 clock is enabled.   |
|       |         |      | Timer 4 clock enable           |
|       |         |      | Set and cleared by software.   |
| Bit 2 | TMR4EN  | rw   | 0: Timer 4 clock is disabled.  |
|       |         |      | 1: Timer 4 clock is enabled.   |
|       |         |      | Timer 3 clock enable           |
|       | TMR3EN  | rw   | Set and cleared by software.   |
| Bit 1 |         |      | 0: Timer 3 clock is disabled.  |
|       |         |      | 1: Timer 3 clock is enabled.   |
|       |         |      |                                |



|       |        |    | Timer 2 clock enable          |
|-------|--------|----|-------------------------------|
| Bit 0 | TMR2EN | rw | Set and cleared by software.  |
| DIC U |        |    | 0: Timer 2 clock is disabled. |
|       |        |    | 1: Timer 2 clock is enabled.  |

# 3.3.9 Backup Domain Control Register (RCC\_BDC)

Address offset: 0x20

Reset value: 0x0000 0000, can only be reset by backup domain reset.

Access: 0 to 3 waiting state. Word, half-word, and byte access. Wait states are inserted in the case of successive accesses to this register.

Note: LSEEN, LSEBYPS, RTCSEL, and RTCEN bits of the backup domain control register (RCC\_BDC) are in the backup domain. As a result, these bits are write protected after reset, and can only be modified by setting the DBP bit in the power control register (PWR\_CTRL). Please refer to <u>Section 4.1</u> for further information. These bits could be reset only by backup domain reset (see <u>Section 3.1.3</u>). Any internal or external reset does not affect these bits.

| Bit       | Name        | Туре | Description                                                       |
|-----------|-------------|------|-------------------------------------------------------------------|
| Bit 31:17 | -           | -    | Reserved. Always read as 0.                                       |
| Bit 16    | BDRST       | rw   | Backup domain software reset                                      |
|           |             |      | Set and cleared by software.                                      |
|           |             |      | 0: Reset is not activated.                                        |
|           |             |      | 1: Reset the entire backup domain.                                |
| Bit 15    | RTCEN       | rw   | RTC clock enable                                                  |
|           |             |      | Set and cleared by software.                                      |
|           |             |      | 0: RTC clock is disabled.                                         |
|           |             |      | 1: RTC clock is enabled.                                          |
| Bit 14:10 | -           | -    | Reserved. Always read as 0.                                       |
| Bit 9:8   | RTCSEL[1:0] | rw   | RTC clock source selection                                        |
|           |             |      | Set by software to select the clock source for the RTC. Once the  |
|           |             |      | RTC clock source is selected, it cannot be changed until the next |



|         |         |    | backup domain reset. It can be reset by setting the BDRST bit.    |
|---------|---------|----|-------------------------------------------------------------------|
|         |         |    | 00: No clock                                                      |
|         |         |    | 01: LSE oscillator is used as RTC clock.                          |
|         |         |    | 10: LSI oscillator is used as RTC clock.                          |
|         |         |    | 11: HSE oscillator divided by 128 is used as RTC clock.           |
|         |         |    |                                                                   |
| Bit 7:3 | -       | -  | Reserved. Always read as 0.                                       |
| Bit 2   | LSEBYPS | rw | External low-speed oscillator bypass                              |
|         |         |    | Set and cleared by software in Debug mode to bypass LSE. This     |
|         |         |    | bit can be written only when the external 32 kHz oscillator is    |
|         |         |    | disabled.                                                         |
|         |         |    | 0: LSE clock is not bypassed.                                     |
|         |         |    | 1: LSE clock is bypassed.                                         |
| Bit 1   | LSESTBL | r  | External low-speed oscillator ready                               |
|         |         |    | Set and cleared by hardware to indicate if external 32 kHz        |
|         |         |    | oscillator is stable. After the LSEEN bit is cleared, this bit is |
|         |         |    | cleared after 6 external low-speed oscillator clock cycles.       |
|         |         |    | 0: External 32 kHz oscillator is not ready.                       |
|         |         |    | 1: External 32 kHz oscillator is ready.                           |
| Bit 0   | LSEEN   | rw | External low-speed oscillator enable                              |
|         |         |    | Set and cleared by software.                                      |
|         |         |    | 0: External 32 kHz oscillator is OFF.                             |
|         |         |    | 1: External 32 kHz oscillator is ON.                              |

# 3.3.10 Control/Status register (RCC\_CTRLSTS)

Address offset: 0x24

Reset value: 0x0C00 0000, reset flag can only be cleared by power reset, while others are cleared by system reset.

Access: 0 to 3 waiting state. Word, half-word, and byte access. Wait states are inserted in the case of successive accesses to this register.



| Bit    | Name     | Туре | Description                                                              |
|--------|----------|------|--------------------------------------------------------------------------|
|        |          |      | Low-power reset flag                                                     |
|        |          |      | Set by hardware when a low-power management reset occurs. It             |
|        |          |      | is cleared by writing to the RSTFC bit.                                  |
| Bit 31 | LPRSTF   | rw   | 0: No low-power management reset occurs.                                 |
|        |          |      | 1: Low-power management reset occurs.                                    |
|        |          |      | For further information on low-power management reset, please            |
|        |          |      | refer to Section 3.1.1 "Low-Power Management Reset."                     |
|        |          |      | Window watchdog reset flag                                               |
|        |          |      | Set by hardware when a window watchdog reset occurs. It is               |
| Bit 30 | WWDGRSTF | rw   | cleared by writing to the RSTFC bit.                                     |
|        |          |      | 0: No window watchdog reset occurs.                                      |
|        |          |      | 1: Window watchdog reset occurs.                                         |
|        |          |      | Independent watchdog reset flag                                          |
|        |          |      | Set by hardware when an independent watchdog reset from VDD              |
| Bit 29 | IWDGRSTF | rw   | domain occurs. It is cleared by writing to the RSTFC bit.                |
|        |          |      | 0: No independent watchdog reset occurs.                                 |
|        |          |      | 1: Independent watchdog reset occurs.                                    |
|        |          |      | Software reset flag                                                      |
|        |          |      | Set by hardware when a software reset occurs. It is cleared by           |
| Bit 28 | SWRSTF   | rw   | writing to the RSTFC bit.                                                |
|        |          |      | 0: No software reset occurs.                                             |
|        |          |      | 1: Software reset occurs.                                                |
|        |          |      | POR/PDR reset flag                                                       |
|        |          |      | Set by hardware when a POR/PDR reset occurs. It is cleared by writing to |
| Bit 27 | PORRSTF  | rw   | the RSTFC bit.                                                           |
|        |          |      | 0: No POR/PDR reset occurs.                                              |
|        |          |      | 1: POR/PDR Reset occurs.                                                 |
|        |          |      | NRST PIN reset flag Setby hardware when a reset in the NRST pin          |
| Bit 26 | PINRSTF  | rw   | occurs. It is cleared by writing to the RSTFC bit.                       |
|        |          |      | 0: No NRST pin reset occurs.                                             |
|        |          |      |                                                                          |

|          |         |      | 1: NRST pin reset occurs.                                                |
|----------|---------|------|--------------------------------------------------------------------------|
| Bit 25   | -       | -    | Reserved. Return 0 after being read.                                     |
|          |         |      | Reset flag clear                                                         |
|          | RSTFC   | 5147 | Set by software to clear the reset flags.                                |
| Bit 24   | KJIFC   | rw   | 0: No effect                                                             |
|          |         |      | 1: Clear the reset flags.                                                |
| Bit 23:2 | -       | -    | Reserved. Return 0 after being read.                                     |
|          | LSISTBL | r    | Internal low-speed oscillator ready                                      |
|          |         |      | Set and cleared by hardware to indicate if the internal 40 kHz RC        |
| Bit 1    |         |      | oscillator is stable. After the LSIEN bit is cleared, LSISTBL is cleared |
|          |         |      | after 3 internal 40 kHz RC oscillator clock cycles.                      |
|          |         |      | 0: Internal 40 kHz RC oscillator clock is not ready.                     |
|          |         |      | 1: Internal 40 kHz RC oscillator clock is ready.                         |
|          |         | rw   | Internal low-speed oscillator enable Set and reset by software.          |
| Bit 0    | LSIEN   |      | 0: Internal 40 kHz RC oscillator is OFF.                                 |
|          |         |      | 1: Internal 40 kHz RC oscillator is ON.                                  |

# 3.3.11 Additional Register (RCC\_MISC)

Address offset: 0x30

| Bit       | Name   | Туре | Description                      |
|-----------|--------|------|----------------------------------|
|           |        | rw   | CLKOUT prescaler                 |
|           |        |      | 0 ~ 7: CLKOUT output             |
|           | MCOPRE |      | 8: CLKOUT output divided by 2    |
| Bit 31:28 |        |      | 9: CLKOUT output divided by 4    |
|           |        |      | 10: CLKOUT output divided by 8   |
|           |        |      | 11: CLKOUT output divided by 16  |
|           |        |      | 12: CLKOUT output divided by 64  |
|           |        |      | 13: CLKOUT output divided by 128 |



|           |                 |    | 14: CLKOUT output divided by 256                     |
|-----------|-----------------|----|------------------------------------------------------|
|           |                 |    | 15: CLKOUT output divided by 512                     |
| Bit 27:26 | -               | -  | Reserved. Return 0 after being read.                 |
|           |                 |    | HSI 6 divider enable                                 |
| Bit 25    | HSI_DIV_EN      | rw | 0: HSI outputs 6 divider clock as 8 MHz.             |
|           |                 |    | 1: HSI outputs undivided clock as 48 MHz.            |
|           |                 |    | USB buffer size                                      |
| Bit 24    | USB768B         | rw | 0: The buffer is 512 byte.                           |
|           |                 |    | 1: The buffer is 768 $\sim$ 1280 byte.               |
| Bit 23:17 | -               | -  | Reserved. Return 0 after being read.                 |
| Bit 16    |                 |    | Microcontroller clock output                         |
| DIL 10    | CLKOUT[3]       | rw | Used with RCC_CFG register bit 26:24                 |
| Bit 15:8  | -               | -  | Reserved. Return 0 after being read.                 |
|           |                 | rw | HSICAL written value                                 |
| Bit 7:0   | HSICAL_KEY[7:0] |    | HSICAL[7:0] can be written only if this bit is 0x5A. |

# 3.3.12 Test Register (RCC\_TEST)

Address offset: 0x50

| Bit       | Name       | Туре | Description                             |
|-----------|------------|------|-----------------------------------------|
| Bit 31:17 | -          | -    | Reserved. Kept as 0.                    |
|           |            |      | CLKOUT to Timer 10 CH0 enable           |
| Bit 16    | MCO2TMR_EN | rw   | 0: CLKOUT does not connect Timer10 CH0. |
|           |            |      | 1: CLKOUT connects Timer10 CH0.         |
| Bit 15:0  | -          | -    | Reserved. Kept as 0.                    |



# 3.3.13 Additional Register (RCC\_MISC2)

Address offset: 0x54

Reset value: 0x0000 000D

| Bit       | Name         | Туре | Description                                                   |
|-----------|--------------|------|---------------------------------------------------------------|
| Bit 31:14 | -            | -    | Reserved. Return 0 after being read.                          |
|           |              |      | HSE clock divider control                                     |
|           |              |      | 00: Divided by 2                                              |
|           |              |      | 01: Divided by 3                                              |
| Bit 13:12 | HSE_DIV_CTRL |      | 10: Divided by 4                                              |
|           |              |      | 11: Divided by 5                                              |
|           |              |      | Note: These bits should be configured after HSE clock stable, |
|           |              |      | or the configuration will be ignored.                         |
| Bit 11:10 | -            | -    | Reserved. Return 0 after being read.                          |
|           |              |      | HSI as system clock frequency select                          |
|           | HSI_SYS_CTRL | rw   | When SYSCLKSEL selects HSI as clock source, the frequency     |
| Bit 9     |              |      | of SYSCLK is:                                                 |
| DIL 9     |              |      | 0: Fixed to 8 MHz, which means to select HSI clock divided by |
|           |              |      | 6                                                             |
|           |              |      | 1: Can be 48 MHz or 8 MHz according to HSI DIV EN             |
| Bit 8     | -            | -    | Reserved                                                      |
| Bit 7:6   | -            | -    | Reserved. Return 0 after being read.                          |
|           |              |      | Auto step clock switch enable                                 |
|           |              |      | As for system clock switch to PLL or switch AHB diviver from  |
|           |              |      | low frequence to high frequence, it is recommended to enable  |
|           | AUTO_STEP_EN | rw   | auto step clock switch function when switch system clock from |
| Bit 5:4   |              |      | low frequence to high frequence(greater then 108MHz).         |
|           |              |      | When enable auto step clock switch function, AHB bus will     |
|           |              |      | halted by hardware until auto step clock switch function      |
|           |              |      | completed.In the meanwhile, DMA is still working, and         |



|         |   |   | interrupts will be recorded.When AHB bus recovery from halt, |
|---------|---|---|--------------------------------------------------------------|
|         |   |   | interrupt service rounte will be excuted.                    |
|         |   |   | 00: Auto step clock switch disable                           |
|         |   |   | 01: Reserved                                                 |
|         |   |   | 10: Reserved                                                 |
|         |   |   | 11: Auto step clock switch enable (when modify AHBPSC or     |
|         |   |   | SYSCLKSEL value, Auto step clock switch function will be     |
|         |   |   | automatic enable.                                            |
| Bit 3:0 | - | - | Reserved. Do not change.                                     |

# 3.3.14 Additional Register (RCC\_INTCTRL)

Address offset: 0x5C

| Bit      | Name         | Туре | Description                                                                                                                                                                        |
|----------|--------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:1 | -            | -    | Reserved. Return 0 after being read.                                                                                                                                               |
| Bit 0    | USB_INT_CTRL | rw   | USBDEV interrupt remapping control<br>0: USBDEV USB_HP uses interrupt 19, and USB_LP uses<br>interrupt 20.<br>1: USBDEV USB_HP uses interrupt 73, and USB_LP uses<br>interrupt 74. |



# 4 Backup Registers (BKPR)

# 4.1 **BKPR Introduction**

The backup registers are 64 16-bit registers for storing 128 bytes of user application data. These registers are located in the backup domain and are powered-on by VDD/VBAT. These registers will not be reset when the device wakes up from Standby mode or by system reset and power reset.

In addition, the BKPR control registers can be used to control tamper detection and RTC calibration function. After reset, accesses to the backup registers and RTC are disabled, and the backup domain is protected against possible write access. To enable accesses to the backup registers and the RTC, proceed as follows:

- Enable the power and backup interface clocks by setting the PWREN and BKPEN bits in the RCC\_APB1EN register.
- Set the DBP bit in the power control register (PWR\_CTRL) to enable access to the backup registers and the RTC.

# 4.2 BKPR Main Features

- 128 bytes data backup registers
- Status/Control register which can control tamper detection with interrupt capability
- Calibration register which can store the RTC calibration value
- RTC calibration clock, RTC alarm pulse, or second pulse output on the TAMPER pin, PC13 (when this pin is not used for tamper detection).

# 4.3 **BKPR Function Overview**

#### 4.3.1 Tamper Detection

The TAMPER pin generates a tamper detection event when the pin changes from 0 to 1 or from 1 to 0. (It depends on the TPALV bit in the backup control register (BKPR\_CTRL).) A tamper detection event will reset all data backup registers.

However, to prevent tamper events from losing, the tamper detection signal is the edge detection signal



logically ANDed with the tamper detection enable bit, to detect tamper events that occur before the TAMPER pin is enabled.

• When TPALV = 0: If the TAMPER pin is already high before enabled (by setting the TPEN bit), an extra tamper event is detected as soon as the TAMPER function is enabled (even if there was no rising edge on the TAMPER pin after TPEN was set).

• When TPALV = 1: If the TAMPER pin is already low before enabled (by setting the TPEN bit), an extra tamper event is detected as soon as the TAMPER function is enabled (even if there was no falling edge on the TAMPER pin after TPEN was set).

By setting the TPIEN bit in the BKPR\_CTRLSTS register, an interrupt is generated when a tamper event is detected. After a tamper event has been detected and cleared, the TAMPER pin should be disabled and then re-enabled by the TPEN bit before writing to the backup data registers again. This can prevent software from writing to the backup data registers when the TAMPER pin value still indicates a tamper detection. This is equivalent to a level detection on the TAMPER pin.

Note: Tamper detection is still active when VDD power is switched off. To avoid unnecessary resetting of the data backup registers, the TAMPER pin should be externally tied to the correct level.

# 4.3.2 RTC Calibration

For the measurement purpose, the RTC clock with a frequency divided by 64 can be output on the TAMPER pin. This is enabled by setting the OT1CAL bit in the RTC clock calibration register (BKPR\_RTCCAL).

The clock can be slowed down up to 121 ppm by configuring CAL[6:0] bits.

# 4.4 **BKPR Registers**

# 4.4.1 Backup Data Register x (BKPR\_DRx) (x = 1, ...,64)

Address offset:  $0x04 \sim 0x28$ ,  $0x40 \sim 0x114$ 



| Bit      | Name     | Туре | Description                                                                                                                                                                                                                                                                                                      |
|----------|----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | DT[15:0] | rw   | Backup data<br>These bits can be written with user data.<br><i>Note:</i> The BKPR_DRx registers are not reset by system reset or power<br>reset or when the device wakes up from Standby mode. They are reset<br>by a backup domain reset or by a TAMPER pin event (if the TAMPER<br>pin function is activated). |

# 4.4.2 RTC Clock Calibration Register (BKPR\_RTCCAL)

Address offset: 0x2C

| Bit       | Name   | Туре | Description                                                             |  |
|-----------|--------|------|-------------------------------------------------------------------------|--|
| Bit 15:12 | -      | -    | Reserved. Always read as 0.                                             |  |
|           |        |      | After ASOE is enabled, this bit can determine clock or second output.   |  |
|           |        |      | 0: Clock or second output is pulse width output form. (Output pulse     |  |
| Bit 11    | TOGEN  | rw   | width is one RTC clock cycle.                                           |  |
|           | 100LN  |      | 1: Clock or second output is rollover output form. (Every clock or      |  |
|           |        |      | second output event will cause a corresponding pin rollover.)           |  |
|           |        |      | Note: This bit is reset only by a backup domain reset.                  |  |
|           |        |      | When selecting calibration clock output, this bit can select 64 divider |  |
|           |        | rw   | output before or after the calibration.                                 |  |
| Bit 10    | CCOS   |      | 0: 64 divider output before calibration                                 |  |
|           |        |      | 1: 64 divider output after calibration                                  |  |
|           |        |      | Note: This bit is reset only by a backup domain reset.                  |  |
|           |        |      | Alarm or second output selection                                        |  |
| Bit 9     |        | - rw | The OT2SEL bit can select either the RTC second pulse signal or the     |  |
| DIL 9     | OT2SEL |      | alarm pulse signal as signal output on the TAMPER pin.                  |  |
|           |        |      | 0: RTC Alarm pulse output is selected.                                  |  |



|         |          |    | Ι                                                                            |
|---------|----------|----|------------------------------------------------------------------------------|
|         |          |    | 1: Second pulse output is selected.                                          |
|         |          |    | Note: This bit is reset only by a backup domain reset.                       |
|         |          |    | Alarm or second output enable                                                |
|         |          |    | According to the setting of the OT2EN bit, this bit allows either the        |
|         |          |    | RTC alarm pulse signal or the second pulse signal output on the              |
| Bit 8   | OT2EN    | rw | TAMPER pin.                                                                  |
|         |          |    | The output pulse duration is one RTC clock cycle. The TAMPER                 |
|         |          |    | function cannot be enabled once the OT2EN bit is set.                        |
|         |          |    | Note: This bit is reset only by a backup domain reset.                       |
|         | OT1CAL   | rw | Calibration clock output                                                     |
|         |          |    | 0: No effect                                                                 |
| Bit 7   |          |    | 1: Setting this bit can output the RTC clock with a frequency divided        |
|         |          |    | by 64 on the TAMPER pin. The TAMPER pin must be disabled when the            |
|         |          |    | OT1CAL bit is set, to avoid undesired tamper detection.                      |
|         |          |    | Note: This bit is reset when the VDD supply is powered off.                  |
|         |          | rw | Calibration value                                                            |
|         |          |    | The calibration value indicates the number of clock pulses that will be      |
| Bit 6:0 | CAL[6:0] |    | ignored every $2^{20}$ clock pulses. This allows the calibration of the RTC, |
|         |          |    | slowing down the clock by steps of $1000000/2^{20}$ ppm. The RTC clock       |
|         |          |    |                                                                              |
|         |          |    | can be slowed down from 0 ppm to 121 ppm.                                    |

# 4.4.3 Backup Control Register (BKPR\_CTRL)

Address offset: 0x30

| Bit           | Name  | Туре | Description                                                                                                                                                                                                                      |  |  |
|---------------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit 15:2      | -     | -    | Reserved. Always read as 0.                                                                                                                                                                                                      |  |  |
| Bit 1         | TPALV | rw   | <ul><li>TAMPER pin active level</li><li>0: A high level on the TAMPER pin resets all data backup registers (if the TPEN bit is set).</li><li>1: A low level on the TAMPER pin resets all data backup registers (if the</li></ul> |  |  |
| <b>V</b> ango |       |      | Hangzhou Vango Technologies, Inc.101 / 782                                                                                                                                                                                       |  |  |

|       |               |  | TPEN bit is set).                                                       |  |
|-------|---------------|--|-------------------------------------------------------------------------|--|
| Bit 0 | Bit 0 TPEN rw |  | TAMPER pin enable<br>0: The TAMPER pin is free for general purpose I/O. |  |
|       |               |  | 1: The TAMPER pin is enabled for tamper detection.                      |  |

*Note:* Setting the TPALV and TPEN bits at the same time is always safe. However, resetting both at the same time will generate a spurious tamper event. Therefore, changing the TPALV bit only when the TPEN bit is 0 is suggested.

# 4.4.4 Backup Control/Status Register (BKPR\_CTRLSTS)

Address offset: 0x34

| Bit      | Name | Туре | Description                                                               |  |
|----------|------|------|---------------------------------------------------------------------------|--|
| Bit 15:0 | -    | -    | Reserved. Always read as 0.                                               |  |
| Bit 9    | TPIF | r    | Tamper interrupt flag                                                     |  |
|          |      |      | This bit is set by hardware when a tamper event is detected and the       |  |
|          |      |      | TPIEN bit is set. This bit is cleared by writing 1 to the CTPIF bit (also |  |
|          |      |      | clears the interrupt). This bit is cleared if the TPIF bit is reset.      |  |
|          |      |      | 0: No tamper interrupt occurred.                                          |  |
|          |      |      | 1: A tamper interrupt occurred.                                           |  |
|          |      |      | Note: This bit is reset only by system reset or by waking up from         |  |
|          |      |      | Standby mode.                                                             |  |
| Bit 8    | TPEF | r    | Tamper event flag                                                         |  |
|          |      |      | This bit is set by hardware when a tamper event is detected. It is        |  |
|          |      |      | cleared by writing 1 to the CTPEF bit.                                    |  |
|          |      |      | 0: No tamper event occurred.                                              |  |
|          |      |      | 1: A tamper event occurred.                                               |  |
|          |      |      | Note: A tamper event resets all the BKPR_DRx registers. They are          |  |
|          |      |      | held in reset as long as the TEF bit is set. If a write to the BKPR_DRx   |  |
|          |      |      | registers is performed when this bit is set, the written value will not   |  |
|          |      |      | be stored.                                                                |  |



| Bit 7:3 | -     | -  | Reserved. Always read as 0.                                         |  |  |
|---------|-------|----|---------------------------------------------------------------------|--|--|
| Bit 2   | TPIEN | rw | Tamper pin interrupt enable                                         |  |  |
|         |       |    | 0: Tamper interrupt is disabled                                     |  |  |
|         |       |    | 1: Tamper interrupt is enabled. (The TPEN bit must also be set in   |  |  |
|         |       |    | the BKPR_CTRL register.)                                            |  |  |
|         |       |    | Note 1: A tamper interrupt does not wake up the core from low-      |  |  |
|         |       |    | power mode.                                                         |  |  |
|         |       |    | Note 2: This bit is reset only by system reset or by waking up from |  |  |
|         |       |    | Standby mode.                                                       |  |  |
| Bit 1   | CTPIF | rw | Clear tamper interrupt                                              |  |  |
|         |       |    | This bit is write only, and is always read as 0.                    |  |  |
|         |       |    | 0: No effect                                                        |  |  |
|         |       |    | 1: Clear the tamper interrupt and the TIF tamper interrupt flag.    |  |  |
| Bit 0   | CTPEF | rw | Clear tamper event                                                  |  |  |
|         |       |    | This bit is write only, and is always read as 0.                    |  |  |
|         |       |    | 0: No effect                                                        |  |  |
|         |       |    | 1: Clear the TPEF tamper event flag (and reset the tamper           |  |  |
|         |       |    | detector).                                                          |  |  |



# **5 Flash Memory Controller (FMC)**

# **5.1 FMC Introduction**

Embedded Flash memory can be used for In-Circuit Programming (ICP) or In-Application Programming (IAP).

In-Circuit Programming (ICP) is used to update all the contents in the Flash memory. It can download user application to the microcontroller through JTAG, SWD protocol, or boot loader. ICP is a fast and effective programming which is free from the inconvenience of package and sockets.

Different from ICP, In-Application Programming (IAP) can use any communication interface supported by the microcontroller (such as I/O interface, USB, CAN, USART, I<sup>2</sup>C, SPI, etc.) to download application or data to the memory. IAP allows users to re-program contents in the Flash memory while applications are running. However, IAP requires that some of the applications are already programmed in the Flash memory with ICP.

Flash memory interface realizes the access to instructions and data on AHB protocols. It speeds up the access to the memory with the help of memory prefetch buffer. Flash memory interface also realizes the logic circuits required by Flash memory program and erase under all operating voltages, including access, write protection, and control of option bytes.

# 5.2 Main Features

- Up to 5120 KB of Flash memory
- A total of up to three pieces of flash memory are used: the first 512 KB capacity is in the first flash memory (bank1), the next 512 KB capacity is in the second flash memory (bank2), and the remaining capacity is in the third flash memory (bank3)
- Flash memory interface of external memory (Bank 3) provided by SPIM interface
- Read interface with prefetch buffer (4x64 bit)
- Option byte loader
- Flash memory program/erase operation
- Read/Write protection
- Low-power mode
- Optional CRC check for block 1 and block 2 in units of Page

# 5.2.1 Flash Memory Architecture

Flash memory is organized into up to 5120KB of main Flash memory and an information block.

|                        | Block    | Name              | Address Range             | Size (bytes) |
|------------------------|----------|-------------------|---------------------------|--------------|
| Main                   | Bank 1   | Page 0            | 0x0800 0000 - 0x0800 07FF | 2 K          |
| Flash                  | 512 KB   | Page 1            | 0x0800 0800 - 0x0800 0FFF | 2 K          |
| Memory                 |          | Page 2            | 0x0800 1000 - 0x0800 17FF | 2 K          |
|                        |          | Page 3            | 0x0800 1800 - 0x0800 1FFF | 2 K          |
|                        |          | Page 4            | 0x0800 2000 – 0x0800 27FF | 2 K          |
|                        |          |                   |                           |              |
|                        |          |                   | · .                       |              |
|                        |          | Page 255          | 0x0807 F800 – 0x0807 FFFF | 2 K          |
|                        | Bank 2   | Page 256          | 0x0808 0000 – 0x0808 07FF | 2 K          |
|                        | 512 KB   | Page 257          | 0x0808 0800 - 0x0808 0FFF | 2 K          |
|                        |          | Page 258          | 0x0808 1000 - 0x0808 17FF | 2 K          |
|                        |          | Page 259          | 0x0808 1800 - 0x0808 1FFF | 2 K          |
|                        |          | Page 260          | 0x0808 2000 - 0x0808 27FF | 2 K          |
|                        |          |                   |                           |              |
|                        |          |                   |                           |              |
|                        |          | Page 511          | 0x080F F800 – 0x080F FFFF | 2 K          |
|                        | Bank 3   |                   | 0x0840 0000 – 0x087F FFFF | 4M           |
| Informati              | on Block | Boot Loader       | 0x1FFF B000 – 0x1FFF EFFF | 16 K         |
|                        |          | User Option Bytes | 0x1FFF F800 – 0x1FFF F82F | 48           |
| Flash Memory Interface |          | FLASH_ACR         | 0x4002 2000 – 0x4002 2003 | 4            |
| Register               |          | FLASH_FCKEY       | 0x4002 2004 – 0x4002 2007 | 4            |
|                        |          | FLASH_OPTKEYR     | 0x4002 2008 – 0x4002 200B | 4            |
|                        |          | FLASH_STS         | 0x4002 200C - 0x4002 200F | 4            |
|                        |          | FLASH_CTRL        | 0x4002 2010 – 0x4002 2013 | 4            |



| FLASH_ADDR   | 0x4002 2014 - 0x4002 2017 | 4  |
|--------------|---------------------------|----|
| Reserved     | 0x4002 2018 – 0x4002 201B | 4  |
| FLASH_UOB    | 0x4002 201C - 0x4002 201F | 4  |
| FLASH_WRPRT  | 0x4002 2020 – 0x4002 2023 | 4  |
| Reserved     | 0x4002 2024 - 0x4002 2043 | 32 |
| FLASH_FCKEY2 | 0x4002 2044 - 0x4002 2047 | 4  |
| Reserved     | 0x4002 2048 - 0x4002 204B | 4  |
| FLASH_STS2   | 0x4002 204C - 0x4002 204F | 4  |
| FLASH_CTRL2  | 0x4002 2050 - 0x4002 2053 | 4  |
| FLASH_ADDR2  | 0x4002 2054 - 0x4002 2057 | 4  |
| Reserved     | 0x4002 2058 - 0x4002 2083 | 44 |
| FLASH_FCKEY3 | 0x4002 2084 - 0x4002 2087 | 4  |
| FLASH_SELECT | 0x4002 2088 - 0x4002 208B | 4  |
| FLASH_STS3   | 0x4002 208C - 0x4002 208F | 4  |
| FLASH_CTRL3  | 0x4002 2090 - 0x4002 2093 | 4  |
| FLASH_ADDR3  | 0x4002 2094 - 0x4002 2097 | 4  |
| FLASH_DA     | 0x4002 2098 – 0x4002 209B | 4  |
| Reserved     | 0x4002 209C - 0x4002 20F3 | 88 |
| CRC_DR       | 0x4002 20F4 - 0x4002 20F7 | 4  |
| CRC_OUTR     | 0x4002 20F8 - 0x4002 2FB  | 4  |
|              |                           |    |

#### Table 5-2 Flash Memory Architecture(V8410N and V8411S)

|        | Block       | Name   | Address Range             | Size (bytes)              |     |
|--------|-------------|--------|---------------------------|---------------------------|-----|
|        | h<br>512 KB | Page 0 | 0x0800 0000 – 0x0800 07FF | 2 K                       |     |
|        |             | Page 1 | 0x0800 0800 – 0x0800 0FFF | 2 K                       |     |
| Main   |             | Page 2 | 0x0800 1000 - 0x0800 17FF | 2 K                       |     |
| Flash  |             |        | Page 3                    | 0x0800 1800 – 0x0800 1FFF | 2 K |
| Memory |             | Page 4 | 0x0800 2000 – 0x0800 27FF | 2 K                       |     |
|        |             |        |                           |                           |     |
|        |             |        |                           | •                         |     |



|            |                | Page 255          | 0x0807 F800 – 0x0807 FFFF | 2 K  |
|------------|----------------|-------------------|---------------------------|------|
|            |                | Page 256          | 0x0808 0000 – 0x0808 07FF | 2K   |
|            |                | Page 257          | 0x0808 0800 – 0x0808 0FFF | 2K   |
|            |                | Page 258          | 0x0808 1000 - 0x0808 17FF | 2K   |
|            | Bank 2         | Page 259          | 0x0808 1800 - 0x0808 1FFF | 2K   |
|            | 512 КВ         | Page 260          | 0x0808 2000 – 0x0808 27FF | 2К   |
|            |                |                   |                           |      |
|            |                |                   |                           | •    |
|            |                | Page 511          | 0x080F F800 – 0x080F FFFF | 2K   |
|            |                | Boot Loader       | 0x1FFF B000 – 0x1FFF EFFF | 16 K |
| Informatio | DN BIOCK       | User Option Bytes | 0x1FFF F800 – 0x1FFF F82F | 48   |
|            |                | FLASH_ACR         | 0x4002 2000 – 0x4002 2003 | 4    |
|            |                | FLASH_FCKEY       | 0x4002 2004 – 0x4002 2007 | 4    |
|            |                | FLASH_OPTKEYR     | 0x4002 2008 – 0x4002 200B | 4    |
|            |                | FLASH_STS         | 0x4002 200C - 0x4002 200F | 4    |
|            |                | FLASH_CTRL        | 0x4002 2010 - 0x4002 2013 | 4    |
|            |                | FLASH_ADDR        | 0x4002 2014 - 0x4002 2017 | 4    |
|            |                | Reserved          | 0x4002 2018 - 0x4002 201B | 4    |
|            |                | FLASH_UOB         | 0x4002 201C - 0x4002 201F | 4    |
| Flash Men  | nory Interface | FLASH_WRPRT       | 0x4002 2020 - 0x4002 2023 | 4    |
| Register   |                | Reserved          | 0x4002 2024 - 0x4002 2043 | 32   |
|            |                | FLASH_FCKEY2      | 0x4002 2044 - 0x4002 2047 | 4    |
|            |                | Reserved          | 0x4002 2048 - 0x4002 204B | 4    |
|            |                | FLASH_STS2        | 0x4002 204C - 0x4002 204F | 4    |
|            |                | FLASH_CTRL2       | 0x4002 2050 - 0x4002 2053 | 4    |
|            | FLASH_ADDR2    |                   | 0x4002 2054 - 0x4002 2057 | 4    |
|            |                | Reserved          | 0x4002 2058 - 0x4002 20F3 | 156  |
|            |                | CRC_DR            | 0x4002 20F4 - 0x4002 20F7 | 4    |
|            |                | CRC_OUTR          | 0x4002 20F8 - 0x4002 2FB  | 4    |
|            |                |                   |                           |      |

Mango

Hangzhou Vango Technologies, Inc.

#### Table 5-3 Flash Memory Architecture(V8410C)

|                    | Block          | Name                              | Address Range             | Size (bytes) |
|--------------------|----------------|-----------------------------------|---------------------------|--------------|
| Main               | Bank 1         | Page 0                            | 0x0800 0000 - 0x0800 07FF | 2К           |
| Flash              | 512 KB         | Page 1                            | 0x0800 0800 - 0x0800 0FFF | 2К           |
| Memory             |                | Page 2                            | 0x0800 1000 - 0x0800 17FF | 2К           |
|                    |                | Page 3                            | 0x0800 1800 - 0x0800 1FFF | 2К           |
|                    |                | Page 4                            | 0x0800 2000 – 0x0800 27FF | 2К           |
|                    |                |                                   |                           |              |
|                    |                |                                   |                           |              |
|                    |                | Page 255                          | 0x0807 F800 – 0x0807 FFFF | 2К           |
|                    | Bank 2         | Page 256                          | 0x0808 0000 – 0x0808 07FF | 2K           |
|                    | 512 KB         | Page 257                          | 0x0808 0800 - 0x0808 0FFF | 2К           |
|                    |                | Page 258 0x0808 1000 - 0x0808 17F |                           | 2К           |
|                    |                | Page 259                          | 0x0808 1800 – 0x0808 1FFF | 2К           |
|                    |                | Page 260                          | 0x0808 2000 – 0x0808 27FF | 2K           |
|                    |                |                                   |                           |              |
|                    |                |                                   |                           |              |
|                    |                | Page 511                          | 0x080F F800 – 0x080F FFFF | 2К           |
| External<br>Memory | Bank 3         |                                   | 0x0840 0000 – 0x0940 0000 | 16 M         |
| Informati          | on Block       | Boot Loader                       | 0x1FFF B000 – 0x1FFF EFFF | 16 K         |
|                    |                | User Option Bytes                 | 0x1FFF F800 – 0x1FFF F82F | 48           |
| Flash Mer          | nory Interface | FLASH_ACR                         | 0x4002 2000 – 0x4002 2003 | 4            |
| Register           |                | FLASH_FCKEY                       | 0x4002 2004 – 0x4002 2007 | 4            |
|                    |                | FLASH_OPTKEYR                     | 0x4002 2008 – 0x4002 200B | 4            |
|                    |                | FLASH_STS                         | 0x4002 200C - 0x4002 200F | 4            |
|                    |                | FLASH_CTRL                        | 0x4002 2010 - 0x4002 2013 | 4            |
|                    |                | FLASH_ADDR                        | 0x4002 2014 - 0x4002 2017 | 4            |
|                    |                | Reserved                          | 0x4002 2018 - 0x4002 201B | 4            |



| FLASH_UOB         0x4002 201C - 0x4002 201F         4           FLASH_WRPRT         0x4002 2020 - 0x4002 2023         4           Reserved         0x4002 2024 - 0x4002 2043         32           FLASH_FCKEY2         0x4002 2044 - 0x4002 2047         4           Reserved         0x4002 2048 - 0x4002 2048         4           FLASH_FCKEY2         0x4002 2048 - 0x4002 2047         4           Reserved         0x4002 2048 - 0x4002 2047         4           FLASH_STS2         0x4002 2050 - 0x4002 2047         4           FLASH_CTRL2         0x4002 2050 - 0x4002 2053         4           FLASH_ADDR2         0x4002 2053         44           FLASH_SELECT         0x4002 2084 - 0x4002 2087         4           FLASH_SELECT         0x4002 2088 - 0x4002 2088         4           FLASH_STS3         0x4002 2086 - 0x4002 2087         4           FLASH_CTRL3         0x4002 2080 - 0x4002 2087         4           FLASH_CTRL3         0x4002 2090 - 0x4002 2093         4           FLASH_CTRL3         0x4002 2090 - 0x4002 2097         4           FLASH_CTRL3         0x4002 2094 - 0x4002 2097         4           FLASH_DDR3         0x4002 2094 - 0x4002 2097         4           FLASH_DA         0x4002 2098 - 0x4002 2097                                                                   |              |                           |    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------------------|----|
| Reserved         0x4002 2024 - 0x4002 2043         32           FLASH_FCKEY2         0x4002 2044 - 0x4002 2047         4           Reserved         0x4002 2048 - 0x4002 2048         4           FLASH_STS2         0x4002 2046 - 0x4002 2048         4           FLASH_STS2         0x4002 2050 - 0x4002 204F         4           FLASH_CTRL2         0x4002 2050 - 0x4002 2053         4           FLASH_ADDR2         0x4002 2054 - 0x4002 2057         4           Reserved         0x4002 2058 - 0x4002 2083         44           FLASH_FCKEY3         0x4002 2088 - 0x4002 2087         4           FLASH_SELECT         0x4002 2088 - 0x4002 2088         4           FLASH_STS3         0x4002 2090 - 0x4002 2087         4           FLASH_CTRL3         0x4002 2090 - 0x4002 2087         4           FLASH_CTRL3         0x4002 2090 - 0x4002 2087         4           FLASH_CTRL3         0x4002 2090 - 0x4002 2087         4           FLASH_DA         0x4002 2090 - 0x4002 2093         4           FLASH_DDR3         0x4002 2097         4           FLASH_DDA         0x4002 2096 - 0x4002 2097         4           Reserved         0x4002 209C - 0x4002 2073         88           CRC_DR         0x4002 20F4 - 0x4002 20F7         4 <td>FLASH_UOB</td> <td>0x4002 201C – 0x4002 201F</td> <td>4</td> | FLASH_UOB    | 0x4002 201C – 0x4002 201F | 4  |
| FLASH_FCKEY2       0x4002 2044 - 0x4002 2047       4         Reserved       0x4002 2048 - 0x4002 204B       4         FLASH_STS2       0x4002 204C - 0x4002 204F       4         FLASH_CTRL2       0x4002 2050 - 0x4002 2053       4         FLASH_ADDR2       0x4002 2054 - 0x4002 2057       4         Reserved       0x4002 2084 - 0x4002 2083       44         FLASH_FCKEY3       0x4002 2084 - 0x4002 2087       4         FLASH_SELECT       0x4002 2088 - 0x4002 208F       4         FLASH_STS3       0x4002 2090 - 0x4002 2097       4         FLASH_ADDR3       0x4002 2094 - 0x4002 2097       4         FLASH_DA       0x4002 2096 - 0x4002 2097       4         FLASH_DA       0x4002 2094 - 0x4002 2097       4         FLASH_DA       0x4002 2096 - 0x4002 2097       4         FLASH_DA       0x4002 2096 - 0x4002 2097       4         Reserved       0x4002 2096 - 0x4002 2097       4         Reserved       0x4002 2096 - 0x4002 2097       4                                                                                                                                                                                                                                                                                                                                                          | FLASH_WRPRT  | 0x4002 2020 – 0x4002 2023 | 4  |
| Reserved         0x4002 2048 - 0x4002 204B         4           FLASH_STS2         0x4002 204C - 0x4002 204F         4           FLASH_CTRL2         0x4002 2050 - 0x4002 2053         4           FLASH_ADDR2         0x4002 2054 - 0x4002 2057         4           Reserved         0x4002 2058 - 0x4002 2083         44           FLASH_FCKEY3         0x4002 2084 - 0x4002 2087         4           FLASH_SELECT         0x4002 2088 - 0x4002 208F         4           FLASH_STS3         0x4002 208C - 0x4002 208F         4           FLASH_CTRL3         0x4002 2090 - 0x4002 2093         4           FLASH_CTRL3         0x4002 2090 - 0x4002 2097         4           FLASH_ADDR3         0x4002 2096 - 0x4002 2097         4           FLASH_DA         0x4002 2096 - 0x4002 2097         4           FLASH_DA         0x4002 2096 - 0x4002 2097         4           FLASH_DA         0x4002 2096 - 0x4002 2097         4           Reserved         0x4002 209C - 0x4002 2097         4           Reserved         0x4002 209C - 0x4002 2097         4                                                                                                                                                                                                                                                          | Reserved     | 0x4002 2024 - 0x4002 2043 | 32 |
| FLASH_STS2       0x4002 204C - 0x4002 204F       4         FLASH_CTRL2       0x4002 2050 - 0x4002 2053       4         FLASH_ADDR2       0x4002 2054 - 0x4002 2057       4         Reserved       0x4002 2058 - 0x4002 2083       44         FLASH_FCKEY3       0x4002 2084 - 0x4002 2087       4         FLASH_SELECT       0x4002 2088 - 0x4002 2087       4         FLASH_STS3       0x4002 208C - 0x4002 208F       4         FLASH_CTRL3       0x4002 2090 - 0x4002 2093       4         FLASH_ADDR3       0x4002 2094 - 0x4002 2097       4         FLASH_DA       0x4002 2098 - 0x4002 209B       4         Reserved       0x4002 2096 - 0x4002 2097       4         FLASH_DA       0x4002 2097       4         Reserved       0x4002 2097 - 0x4002 2097       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | FLASH_FCKEY2 | 0x4002 2044 - 0x4002 2047 | 4  |
| FLASH_CTRL2       0x4002 2050 - 0x4002 2053       4         FLASH_ADDR2       0x4002 2054 - 0x4002 2057       4         Reserved       0x4002 2058 - 0x4002 2083       44         FLASH_FCKEY3       0x4002 2084 - 0x4002 2087       4         FLASH_SELECT       0x4002 2088 - 0x4002 2088       4         FLASH_STS3       0x4002 208C - 0x4002 208F       4         FLASH_CTRL3       0x4002 2090 - 0x4002 2093       4         FLASH_ADDR3       0x4002 2094 - 0x4002 2097       4         FLASH_DA       0x4002 2098 - 0x4002 209B       4         Reserved       0x4002 209C - 0x4002 2097       4         Reserved       0x4002 209C - 0x4002 2097       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Reserved     | 0x4002 2048 - 0x4002 204B | 4  |
| FLASH_ADDR2       0x4002 2054 - 0x4002 2057       4         Reserved       0x4002 2058 - 0x4002 2083       44         FLASH_FCKEY3       0x4002 2084 - 0x4002 2087       4         FLASH_SELECT       0x4002 2088 - 0x4002 2088       4         FLASH_STS3       0x4002 208C - 0x4002 208F       4         FLASH_CTRL3       0x4002 2090 - 0x4002 2093       4         FLASH_ADDR3       0x4002 2094 - 0x4002 2097       4         FLASH_DA       0x4002 2098 - 0x4002 209B       4         Reserved       0x4002 209C - 0x4002 20F3       88         CRC_DR       0x4002 20F4 - 0x4002 20F7       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | FLASH_STS2   | 0x4002 204C - 0x4002 204F | 4  |
| Reserved         0x4002 2058 - 0x4002 2083         44           FLASH_FCKEY3         0x4002 2084 - 0x4002 2087         4           FLASH_SELECT         0x4002 2088 - 0x4002 208B         4           FLASH_STS3         0x4002 208C - 0x4002 208F         4           FLASH_CTRL3         0x4002 2090 - 0x4002 2093         4           FLASH_ADDR3         0x4002 2094 - 0x4002 2097         4           FLASH_DA         0x4002 2098 - 0x4002 209B         4           Reserved         0x4002 209C - 0x4002 20F3         88           CRC_DR         0x4002 20F4 - 0x4002 20F7         4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | FLASH_CTRL2  | 0x4002 2050 - 0x4002 2053 | 4  |
| FLASH_FCKEY3       0x4002 2084 - 0x4002 2087       4         FLASH_SELECT       0x4002 2088 - 0x4002 208B       4         FLASH_STS3       0x4002 208C - 0x4002 208F       4         FLASH_CTRL3       0x4002 2090 - 0x4002 2093       4         FLASH_ADDR3       0x4002 2094 - 0x4002 2097       4         FLASH_DA       0x4002 2098 - 0x4002 209B       4         Reserved       0x4002 209C - 0x4002 20F3       88         CRC_DR       0x4002 20F4 - 0x4002 20F7       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | FLASH_ADDR2  | 0x4002 2054 - 0x4002 2057 | 4  |
| FLASH_SELECT       0x4002 2088 - 0x4002 208B       4         FLASH_STS3       0x4002 208C - 0x4002 208F       4         FLASH_CTRL3       0x4002 2090 - 0x4002 2093       4         FLASH_ADDR3       0x4002 2094 - 0x4002 2097       4         FLASH_DA       0x4002 2098 - 0x4002 209B       4         Reserved       0x4002 209C - 0x4002 20F3       88         CRC_DR       0x4002 20F4 - 0x4002 20F7       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Reserved     | 0x4002 2058 - 0x4002 2083 | 44 |
| FLASH_STS3       0x4002 208C - 0x4002 208F       4         FLASH_CTRL3       0x4002 2090 - 0x4002 2093       4         FLASH_ADDR3       0x4002 2094 - 0x4002 2097       4         FLASH_DA       0x4002 2098 - 0x4002 209B       4         Reserved       0x4002 209C - 0x4002 20F3       88         CRC_DR       0x4002 20F4 - 0x4002 20F7       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | FLASH_FCKEY3 | 0x4002 2084 - 0x4002 2087 | 4  |
| FLASH_CTRL3       0x4002 2090 - 0x4002 2093       4         FLASH_ADDR3       0x4002 2094 - 0x4002 2097       4         FLASH_DA       0x4002 2098 - 0x4002 209B       4         Reserved       0x4002 209C - 0x4002 20F3       88         CRC_DR       0x4002 20F4 - 0x4002 20F7       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | FLASH_SELECT | 0x4002 2088 - 0x4002 208B | 4  |
| FLASH_ADDR3       0x4002 2094 - 0x4002 2097       4         FLASH_DA       0x4002 2098 - 0x4002 209B       4         Reserved       0x4002 209C - 0x4002 20F3       88         CRC_DR       0x4002 20F4 - 0x4002 20F7       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | FLASH_STS3   | 0x4002 208C - 0x4002 208F | 4  |
| FLASH_DA       0x4002 2098 - 0x4002 209B       4         Reserved       0x4002 209C - 0x4002 20F3       88         CRC_DR       0x4002 20F4 - 0x4002 20F7       4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | FLASH_CTRL3  | 0x4002 2090 - 0x4002 2093 | 4  |
| Reserved         0x4002 209C - 0x4002 20F3         88           CRC_DR         0x4002 20F4 - 0x4002 20F7         4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | FLASH_ADDR3  | 0x4002 2094 - 0x4002 2097 | 4  |
| CRC_DR         0x4002 20F4 - 0x4002 20F7         4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | FLASH_DA     | 0x4002 2098 – 0x4002 209B | 4  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reserved     | 0x4002 209C - 0x4002 20F3 | 88 |
| CRC_OUTR 0x4002 20F8 - 0x4002 2FB 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | CRC_DR       | 0x4002 20F4 - 0x4002 20F7 | 4  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | CRC_OUTR     | 0x4002 20F8 - 0x4002 2FB  | 4  |

The Flash memory is organized as 32-bit wide memory cells, which stores codes and data constants. Every Flash memory block in V84XXX microcontroller has a specific address.

Information block is divided into two parts:

• System memory is used for boot loader stored in the system memory bootstrapping mode. This area is reserved only for Artery, and the boot loader uses USART1, USART2 or USB(DFU) serial interface to program the Flash memory. This area is programmed and locked during manufacturing to prevent users from erase or write.

#### Option bytes

Write to main memory block and information block is controlled by embedded Flash program/erase controller (FPEC). High voltages of program and erase are generated internally.

The Flash memory provides two kinds of protection to avoid illegal access (read, write, and erase):



Hangzhou Vango Technologies, Inc.

- Page write protection
- Read protection (Please refer to <u>Section 5.3.3</u> for further information.)

During a write operation to the Flash memory, any read operation to the Flash memory will lock the bus. Read operation can only be executed successfully after write operation is completed. That is, when write or erase operation is in process, reading code or data is not allowed.

When Flash programming (write or erase) is in process, internal RC oscillator (HSI) must be ON. Flash memory can be programmed with ICP or IAP.

Note: In low-power mode, all operations in the Flash memory are aborted.

#### 5.2.2 The third flash memory (V8411N Bank3)

The third flash memory (bank3) can support reading and writing with a maximum capacity of 4M bytes. The operation method is the same as that of the first flash memory (bank1) and the second flash memory (bank2). The additional ciphertext protection function can be determined by selecting the byte Whether the data in bank3 is encrypted or not, and the encryption range is controlled by the FLASH\_DA register.

Note: The third flash memory only supports word or half-word operations.

Figure 5-1 Programming process



Note: The external flash memory module organization only supports word or half-word operations.



## 5.2.3 External Flash Memory Organization (V8410C bank3)

The Flash memory provides external Flash memory block, and the controls external SPI Flash memory (Bank 3) through SPIM transmission interface. The maximum capacity for read and write is 16 MB, and the operation is as same as Bank 1 and Bank 2. For additional encryption function, users can decide whether to encrypt the data according to option byte access, and control the range of encryption with the FLASH\_DA register.

AHB clock (HCLK), used as the reference clock of SPIM, provides HCLK/2 clock for external SPIM through SPIM transmission interface.

SPIM = External SPI Flash memory expansion (application execution/data storing/program and data can be encrypted). SPIM and USB interface use the same pin, and the two functions can not be used at the same time.

Note: The SPIM has to be accessed by word or half-word (byte access is not allowed).

Figure 5-2 Programming Process



Figure 5-3 Reference Circuit for External Memory





### **5.3 Function Overview**

#### 5.3.1 Read Operation

The embedded Flash memory block can be addressed directly in the common memory space. Any 8/16/32bit data read operation can access the contents in Flash memory block and obtain the corresponding data.

Read interface includes a read controller in the Flash memory and an AHB interface connected to the CPU. The main function of this interface is to generate control signal of reading Flash memory and to prefetch the instruction block required by the CPU. Prefetch instruction block is only used for fetching instructions on I-Code bus, and the data constants are accessed through D-Code bus. The access target of these two buses are the same Flash memory block, and access to D-Code has higher priority than prefetch instruction.

#### 5.3.1.1 Instruction Fetch

Cortex<sup>®</sup>-M4F fetches instructions on I-Code bus and fetches data on D-Code bus. Prefetch instruction block can effectively increase the efficiency of I-Code bus access.

Prefetch buffer includes two data blocks, each of which is 8 bytes. Prefetch instruction (data) directly maps to the Flash memory, and since the size of data block is the same as the bandwidth of the Flash memory, reading prefetch instruction can be completed within a read cycle.

Setting prefetch buffer can make CPU execution faster, as when the CPU fetches one word, the next word is readily available in the prefetch buffer at the same time.



The prefetch controller decides whether to access the flash memory according to the available space in the prefetch buffer. When there is at least one free space in the prefetch buffer, the prefetch controller starts a read operation.

Clearing a control bit in the flash access control register can turn off the prefetch buffer. The prefetch buffer is turned on after the chip is reset.

Note: When the prescaler coefficient of the AHB clock is not '1', the prefetch buffer must be turned on (FLASH\_ACR[4]=1). If there is no high-frequency clock in the system, that is, when the HCLK frequency is low, the flash memory access only needs half a HCLK cycle (half-cycle flash memory access can only be performed when the clock frequency is lower than 8 MHz, use HSI or HSE and turn off the PLL This frequency can be obtained from time to time); there is a control bit in the flash memory access control register to select this working mode.

Note: When the prefetch buffer is used and the prescaler coefficient of the AHB clock is not '1', the halfcycle access method can not be used. In order to maintain the control signal for reading flash memory, the ratio of the clock cycle of the prefetch controller to the flash memory access time is controlled by the flash memory access controller; this value gives the flash memory control signal required when the data can be read correctly The number of clock cycles; after the chip is reset, the value is '0', and the flash memory access is only one clock cycle.

#### 5.3.1.2 D-Code Interface

D-Code interface includes simple AHB interface on CPU and logic circuit that requests access to the arbiter of Flash access controller. Access to D-code has higher priority than access to prefetch instruction. This interface uses access time regulator block of prefetch buffer.

#### 5.3.1.3 Flash Access Controller

This block is the arbiter of the instruction prefetch request on I-Code and read request on D-Code interface. Request from D-Code interface has higher priority than request from I-Code.

#### 5.3.2 Flash Program/Erase Controller (FPEC)

FPEC block controls Flash program/erase operation, and it includes 17 32-bit registers. As long as CPU does not access Flash memory, Flash operation will not delay CPU execution.

• FPEC key register (FLASH\_FCKEY)



Hangzhou Vango Technologies, Inc.

- Option bytes key register (FLASH\_OPTKEYR)
- Flash status register (FLASH\_STS)
- Flash control register (FLASH\_CTRL)
- Flash address register (FLASH\_ADDR)
- Option bytes register (FLASH\_UOB)
- Write protection register (FLASH\_WRPRT)
- FPEC key register 2 (FLASH\_FCKEY2)
- Flash status register 2 (FLASH\_STS2)
- Flash control register 2 (FLASH\_CTRL2)
- Flash address register 2 (FLASH\_ADDR2)
- FPEC key register 3 (FLASH\_FCKEY3)
  - Flash option register (FLASH\_SELECT)
  - Flash status register 3 (FLASH\_STS3)
  - Flash control register 3 (FLASH\_CTRL3)
  - Flash address register 3 (FLASH\_ADDR3)
  - Flash decode address register (FLASH\_DA)

#### 5.3.2.1 Key Value

There are three key values:

- RDPRTEN key =  $0 \times 00A5$
- KEY1 = 0x45670123
- KEY2 = 0xCDEF89AB

#### 5.3.2.2 Unlock the Flash Memory

After reset, FPEC block is protected. FLASH\_CTRLx register can not be written. FPEC block can be unlocked by writing certain sequence to FLASH\_FCKEYx register. This sequence is to write two key values (KEY1 and KEY2, see <u>Section 5.3.2.1</u>) to FLASH\_FCKEYx. Incorrect sequence will lock FPEC block and FLASH\_CTRLx register until next reset.

Writing incorrect key sequence also leads to bus error. Bus error occurs when the first key value written is not KEY1, or when the first key value written is KEY1 but the second key value written is not KEY2.



FPEC block and FLASH\_CTRLx register could be locked by setting the LOCK bit in the FLASH\_CTRLx register. At this time, FPEC can be unlocked by writing the correct key values to FLASH\_FCKEYx.

#### 5.3.2.3 Main Flash Programming

The Flash memory can be programmed with 32 bits, 16 bits or 8 bits at a time. When the PRGM bit in FLASH\_CTRLx register is '1', writing a word/half-word/byte to a Flash address will activate one programming operation. In the process of programming (the BSY bit is '1'), any read/write operation to the Flash memory will stop the CPU until this Flash programming is completed.

Figure 5-4 Process of the Programming



#### Standard programming

In this mode, CPU programs/writes Flash memory with standard word, half-word or byte method, and the PRGM bit in the FLASH\_CTRLx register must be set. FPEC first reads the contents of the designated address and checks if it is erased. If it is not erased, then programming is not executed, and warning on the PRGMFLR bit in the FLASH\_STSx register is issued (The only exception is when the value being programmed is 0x0000\_0000/0x0000/0x00, 0x0000\_0000/0x0000/0x000 can be programmed successfully without setting the PRGMFLR bit). If the designated address is under write protection in FLASH\_WRPRT, then programming is not executed and setting the WRPRTFLR bit in FLASH\_STSx to issue a warning. When the PRCDN bit in the FLASH\_STSx register becomes `1', the programming is completed.



The process of standard Flash programming is in the following order:

• Check the BSY bit in the FLASH\_STSx register to confirm that there is no other programming operation in process;

- Set the PRGM bit in the FLASH\_CTRLx register;
- Write the word, half-word or byte to be programmed to the designated address;
- Wait until the BSY bit becomes '0';
- Read the address written and verify the data.

Note: When the BSY bit in the FLASH\_STSx register is '1', write operation to any register is not allowed.

#### 5.3.2.4 Flash Erase

Flash memory erase includes mass erase and Page erase.

#### Page Erase

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

- Check the BSY bit in the FLASH\_STSx register to confirm that there is no other programming operation in process;
- Set the PGERS bit in the FLASH\_CTRLx register;
- Select the Page to be erased with the FLASH\_ADDRx register;
- Set the RSTR bit in the FLASH\_CTRLx register;
- Wait until the BSY bit becomes '0';
- Read and verify the erased Page.

Figure 5-5 Process of Flash Memory Page Erase





#### Mass Erase

Mass erase function can erase all the Flash memory in the user area. Information block will not be affected by this operation. The following process is recommended:

- Check the BSY bit in the FLASH\_STSx register to confirm that there is no other programming operation in process;
- Set the CHPERS bit in the FLASH\_CTRLx register;
- Set the RSTR bit in the FLASH\_CTRLx register;
- Wait until the BSY bit becomes '0';
- Read and verify all the Pages.

Figure 5-6 Process of Flash Memory Mass Erase





#### 5.3.2.5 Option Byte Programming

Option byte programming is different from common user address. The number of option bytes is only 24 bytes (4 bytes for write protection, 1 byte for read protection, 1 byte for configuration option, 2 bytes for storing user data). After unlocking FPEC, KEY1 and KEY 2 (See Section 5.3.2.1) should be written to the FLASH\_OPTKEYR register respectively, and the UOBWE bit in the FLASH\_CTRL register will be set. At this time, option byte programming can be executed: after setting the UOBPRGM bit in the FLASH\_CTRL register, write the half-word to the designated address.

FPEC will first read the contents of option bytes in the designated address and checks if it is erased. If it is not, then the programming will not be executed and a warning on the WRPRTFLR bit in the FLASH\_STS register will be issued. When the PRCDN bit in the FLASH\_STS register becomes `1', the programming is completed.

FPEC uses the low bytes in half-word to calculate high byte automatically (High bytes are the opposites of the low bytes), and activates the programming operation. This can ensure that the option bytes and their opposites are always correct.

The programming operation is in the following order:

• Check the BSY bit in the FLASH\_STS register to confirm that there is no other programming operation in process;



- Unlock the UOBWE bit in the FLASH\_CTRL register;
- Set the UOBPRGM bit in the FLASH\_CTRL register;
- Write the half-word to be programmed to the designated address;
- Wait until the BSY bit becomes '0';
- Read the address written and verify the data.

When the read protection option of Flash memory changes from "protected" to "unprotected", a mass erase of user Flash memory will be executed automatically before reset read protection option. If users change other options aside from read protection, then mass erase will not be executed. This erase operation protects the contents of Flash memory from illegal read out.

#### Process of erase

The erase operation (OPTERASE) of option bytes is in the following order:

• Check the BSY bit in the FLASH\_STS register to confirm that there is no other programming operation in process;

- Unlock the UOBWE bit in the FLASH\_CTRL register;
- Set the UOBERS bit in the FLASH\_CTRL register;
- Set the RSTR bit in the FLASH\_CTRL register;
- Wait until the BSY bit becomes '0';
- Read and verify the erased option bytes.

#### 5.3.3 Protection

User code area in the Flash memory can prevent illegal read out and also protect the Pages in the Flash memory from inadvertent operation when programming errors occur. The base unit of write protection is two Pages.

#### 5.3.3.1 Write Protection

If programming or erase operation is executed on a protected Page, an error flag will be returned in the Flash status register (FLASH\_STS).

The following steps can be used to disable write protection:

• Use the UOBERS bit in the Flash control register (FLASH\_CTRL) to erase the whole option byte



area;

Write correct RDP code 0xA5 to enable read access;

• Reset the system and reload option bytes (including new WRP[3:0] byte); write protection is disabled.

#### 5.3.3.2 Read Protection

This protection is activated by setting the RDP option bytes, and RDP option bytes are loaded by system reset. When the protection byte is written with the corresponding values, the following protection will be executed:

• Only read operation from user code to main Flash memory is allowed (enabled by main Flash memory with non-Debug method).

• Page 0~1 are automatically added with write protection, and other memories can be programmed with the codes executed in the main Flash memory (to enable functions like IAP or data storing), but write or erase operation are not allowed in Debug mode or after internal SRAM is enabled (except for mass erase).

All the functions that load codes from internal SRAM through JTAG/SWD and execute the codes are still valid, and can also be activated from internal SRAM through JTAG/SWD. This function can be used to disable read protection. When the option bytes of read protection turn to the unprotected values, mass erase process will be proceeded.

When RDP option bytes and their opposites include the following value pairs, the Flash memory is in protection:

| RDP byte value | Opposite of RDP value        | Read Protection Status |  |
|----------------|------------------------------|------------------------|--|
| 0xFF           | 0xFF                         | Protected              |  |
| RDPRTEN        | Inverse code of RDP byte     | Unprotected            |  |
| Any value      | Not Inverse code of RDP byte | Protected              |  |

Table 5-4 Flash Memory Protection Status

Note: Erasing the option byte block will not cause automatic mass erase, since the result of erase 0xFF is equal to the protected status.

The process of disabling read protection is as follows:



• Erase the whole option byte area, and the read protection code (RDP) will turn to 0xFF. Read protection is still valid at this time;

• Write correct RDP code 0xA5 to disable memory protection, and this action will first cause mass erase to all user Flash memories.

• Reset (Power-on reset) and reload option bytes (and new RDP code). Read protection will be disabled at this time.

Note: Boot loader can also be used to disable the read protection (In this case, option bytes can be reloaded just by system reset).

#### **5.3.3.3 Option Byte Block Write Protection**

By default, option byte block can always be read and is under write protection. To execute write operation (program and erase), write correct key sequence (the same as LOCK) to OPTKEYR, and enable the write operation to option bytes. The UOBWE bit in the FLASH\_CTRL register then shows that write operation is allowed. Write operation will be disabled if this bit is cleared.

#### 5.3.4 Option Byte Description

Option bytes include 24 bytes, which are configured according to users' needs; for example, users can select hardware watchdog or software watchdog.

In option bytes, every 32-bit word is categorized into the following format:

| Table | 5-5 | Option | Bvte | Format |
|-------|-----|--------|------|--------|
| lable | 55  | option | Dyte | ronnac |

| Bit 31:24                | Bit 23:16    | Bit 15:8                 | Bit 7:0      |
|--------------------------|--------------|--------------------------|--------------|
| Opposite of option byte1 | Option byte1 | Opposite of option byte0 | Option byte0 |

option bytes are organized in the option byte block:

| Address     | [31:24] | [23:16] | [15:8] | [7:0] |
|-------------|---------|---------|--------|-------|
| 0x1FFF_F800 | uUSER   | USER    | nRDP   | RDP   |
| 0x1FFF_F804 | nData1  | Data1   | nData0 | Data0 |
| 0x1FFF_F808 | nWRP1   | WRP1    | nWRP0  | WRP0  |
| 0x1FFF_F80C | nWRP3   | WRP3    | nWRP2  | WRP2  |



| 0x1FFF_F810 | Reserved                | Reserved  | nEOPB0     | EOPB0     |
|-------------|-------------------------|-----------|------------|-----------|
| 0x1FFF_F814 |                         |           |            |           |
| 0x1FFF_F818 | Reserved for future use |           |            |           |
| 0x1FFF_F81C |                         |           |            |           |
| 0x1FFF_F820 | nBANK3KEY1              | BANK3KEY1 | nBANK3KEY0 | BANK3KEY0 |
| 0x1FFF_F824 | nBANK3KEY3              | BANK3KEY3 | nBANK3KEY2 | BANK3KEY2 |
| 0x1FFF_F828 | nBANK3KEY5              | BANK3KEY5 | nBANK3KEY4 | BANK3KEY4 |
| 0x1FFF_F82C | nBANK3KEY7              | BANK3KEY7 | nBANK3KEY6 | BANK3KEY6 |

Table 5-7 User Option Byte Description

RDP: Read Protection Option Byte(stored in FLASH\_UOB[1]).

Read protection can help users protect the codes stored in the Flash Memory. This function is enabled

by setting one option byte in the information block. After writing the correct value (RDPRTEN

Key=0x00A5) to this option byte, the Flash memory allows read access.

USR: User option byte(stored in FLASH\_UOB[9:2]).

This byte is used for the configuration of the following functions:

- Select main memory boot: Bank 1 or Bank 2

- Select watchdog event: hardware or software

- Reset event when entering Stop mode (STOP)

- Reset event when entering Standby mode

| Bit 23:20 | 0xF: Unused                                                                 |
|-----------|-----------------------------------------------------------------------------|
| Bit 19    | вторт                                                                       |
|           | 0: When configuring boot from main memory, boot from Bank 2. If there is no |
|           | boot loader in Bank 2, boot from Bank 1.                                    |
|           | 1: When configuring boot from main memory (by default), boot from Bank 1.   |
| Bit 18    | nRST_STDBY                                                                  |
|           | 0: Reset is generated when entering Standby mode.                           |
|           | 1: Reset is not generated when entering Standby mode.                       |
| Bit 17    | nRST_STOP                                                                   |
|           | 0: Reset is generated when entering Stop mode (STOP).                       |
|           | 1: Reset is not generated when entering Stop mode (STOP).                   |
| Bit 16    | WDG_SW                                                                      |
|           |                                                                             |



|                                                                                     | 0: Hardware watchdog                                                               |  |  |  |  |
|-------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--|--|--|--|
|                                                                                     | 1: Software watchdog                                                               |  |  |  |  |
| WRPx: Flash memor                                                                   | y write protection option byte(stored in FLASH_WRPRT)                              |  |  |  |  |
| Every bit in the WRF                                                                | Px option byte is used to protect the two memory Pages (2K byte/Page) in the       |  |  |  |  |
| main memory. How                                                                    | ever, Bit 7 in WRP3 is used to protect Page 62 and beyond:                         |  |  |  |  |
| 0: Write protection i                                                               | s enabled.                                                                         |  |  |  |  |
| 1: Write protection i                                                               | s disabled. Four user bytes are used to protect the main Flash memory and the      |  |  |  |  |
| external Flash mem                                                                  | ory.                                                                               |  |  |  |  |
| WRP0: Page 0 ~ 15                                                                   | write protection(stored in FLASH_WRPRT[7:0]) WRP1: Page 16 $\sim$ 31 write         |  |  |  |  |
| protection(stored in                                                                | FLASH_WRPRT[15:8]) WRP2: Page 32 ~ 47 write protection(stored in                   |  |  |  |  |
| FLASH_WRPRT[23:1                                                                    | 6])                                                                                |  |  |  |  |
| WRP3: Bit 0 ~ 6 are                                                                 | for Page 48 $\sim$ 61 write protection(stored in FLASH_WRPRT[31:24]); Bit 7 is for |  |  |  |  |
| Page 62                                                                             |                                                                                    |  |  |  |  |
| $\sim$ 511 and bank3 wi                                                             | rite protection.                                                                   |  |  |  |  |
| Datax: 2-byte user data                                                             |                                                                                    |  |  |  |  |
| This address can be                                                                 | programmed with the programming methods of option bytes. Data1: user               |  |  |  |  |
| data1(stored in FLA                                                                 | SH_UOB[25:18])                                                                     |  |  |  |  |
| Data0: user data0(s                                                                 | Data0: user data0(stored in FLASH_UOB[17:10])                                      |  |  |  |  |
| EOPB0: Extended op                                                                  | EOPB0: Extended option byte                                                        |  |  |  |  |
| Bit 0                                                                               | 0: On-chip SRAM is 640 KB.                                                         |  |  |  |  |
|                                                                                     | 1: On-chip SRAM is 1024 KB.                                                        |  |  |  |  |
| BANK3KEYx: Key value of cypher text access area in Bank 3.                          |                                                                                    |  |  |  |  |
| Bank3 is plain text when the following three types of BANK3KEYx values are written. |                                                                                    |  |  |  |  |
| {nBANK3KEYx, BANK3KEYx}:                                                            |                                                                                    |  |  |  |  |
| 0xFFFF                                                                              |                                                                                    |  |  |  |  |
| 0xFF00                                                                              | 0xFF00                                                                             |  |  |  |  |
| -0x00FF                                                                             |                                                                                    |  |  |  |  |

After every system reset, option byte loader reads the data in information block and stores the data in the register. Every option byte has its opposite bit in the information block. When loading the option bytes, the opposite bits can be used to verify whether the option bytes are correct. If there is any mismatch, an option byte error flag (UOBFLR) will be generated. When the option byte error is generated, the corresponding option byte is forced to be 0xFF. When both the option byte and its opposite bits are



0xFF (the status after being erased), disable the above-mentioned verification function.

All the option bytes (excluding their opposites) are used to configure this microcontroller. CPU can select registers. Please refer to Section 5.4 for more details.



### 5.4 FMC Registers

#### 5.4.1 Flash Access Control Register (FLASH\_ACR)

Address offset: 0x00

#### Reset value: 0x0000 0030

| Bit      | Name   | Туре | Description                                       |  |
|----------|--------|------|---------------------------------------------------|--|
| Bit 31:6 | -      | -    | Reserved. Must be kept at reset value '0'.        |  |
| Bit 5    | PRFTBS | r    | Prefetch buffer status                            |  |
|          |        |      | This bit indicates the status of prefetch buffer. |  |
|          |        |      | 0: Prefetch buffer is OFF;                        |  |
|          |        |      | 1: Prefetch buffer is ON.                         |  |
| Bit 4    | PRFTBE | rw   | prefetch buffer enable                            |  |
|          |        |      | 0: Close the prefetch buffer;                     |  |
|          |        |      | 1: Enable prefetch buffer                         |  |
| Bit 3    | HLFCYA | rw   | Flash half-cycle access enable                    |  |
|          |        |      | 0: Prohibit half-cycle access;                    |  |
|          |        |      | 1: Enable half-cycle access.                      |  |
| Bit 2:0  | -      | -    | Reserved.                                         |  |

#### 5.4.2 FPEC Key Register (FLASH\_FCKEY)

Only used in Flash memory Bank 1.

Address offset: 0x04

Reset value: xxxx

| Bit      | Name | Туре | Description                                          |
|----------|------|------|------------------------------------------------------|
| Bit 31:0 | KEY  | w    | FPEC key<br>These bits are used for FPEC unlock key. |



#### 5.4.3 Flash OPTKEY Register (FLASH\_OPTKEYR)

Address offset: 0x08

Reset value: xxxx xxxx

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

| Bit      | Name    | Туре | Description                                                                   |
|----------|---------|------|-------------------------------------------------------------------------------|
| Bit 31:0 | OPTKEYR | w    | Option bytes key<br>These bits are used for option bytes key to unlock UOBWE. |

#### 5.4.4 Flash Status Register (FLASH\_STS)

Only used in Flash memory Bank 1.

Address offset: 0x0C

| Bit      | Name     | Туре | Description                                                        |
|----------|----------|------|--------------------------------------------------------------------|
| Bit 31:6 | -        | -    | Reserved. Must be kept at reset value '0'.                         |
| Bit 5    | PRCDN    | rw   | Process Done                                                       |
|          |          |      | When Flash memory operation (program/erase) is completed, this bit |
|          |          |      | is set by hardware. This bit is cleared by writing `1'.            |
|          |          |      | Note: Every successful program or erase will set PRCDN status.     |
| Bit 4    | WRPRTFLR | rw   | Write protection error                                             |
|          |          |      | When programming write-protected Flash memory address, this bit is |
|          |          |      | set by hardware. This bit is cleared by writing `1'.               |
| Bit 3    | -        | -    | Reserved. Must be kept at reset value '0'.                         |
| Bit 2    | PRGMFLR  | rw   | Programming error                                                  |
|          |          |      | When programming address of which the content is not '0xFFFF',     |
|          |          |      | this bit is set by hardware. This bit is cleared by writing '1'.   |
|          |          |      | Note: Before programming, the RSTR bit in the FLASH_CTRL           |
|          |          |      | register must be cleared.                                          |



| Bit 1 | -   | - | Reserved. Must be kept at reset value '0'.                             |
|-------|-----|---|------------------------------------------------------------------------|
| Bit 0 | BSY | r | Busy flag                                                              |
|       |     |   | This bit indicates that Flash memory operation is in process. This bit |
|       |     |   | is set when Flash memory operation starts; it is cleared when          |
|       |     |   | operation is completed or an error occurs.                             |

#### 5.4.5 Flash Control Register (FLASH\_CTRL)

Only used in Flash memory Bank 1.

Address offset: 0x10

| Bit          | Name    | Туре | Description                                                                                                                                                                                                           |
|--------------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:13    | -       | -    | Reserved. Must be kept at reset value '0'.                                                                                                                                                                            |
| Bit 12       | PRCDNIE | rw   | Process done interrupt enable<br>This bit enables interrupt when the PRCDN bit in the FLASH_STS<br>register becomes '1'.<br>0: Interrupt is disabled;<br>1: Interrupt is enabled.                                     |
| Bit 11, 8, 3 | -       | -    | Reserved. Must be kept at reset value '0'.                                                                                                                                                                            |
| Bit 10       | ERRIE   | rw   | Error status interrupt enable<br>This bit enables interrupt when FPEC errors occur. (When the<br>PRGMFLR/WRPRTFLR in FLASH_STS register is set.)<br>0: Interrupt is disabled;<br>1: Interrupt is enabled.             |
| Bit 9        | UOBWE   | rw   | Option bytes write enable<br>When this bit is set, programming to option bytes is enabled. This<br>bit is set when writing correct key sequence to FLASH_OPTKEYR<br>register.<br>This bit can be cleared by software. |
| Bit 7        | LOCK    | rw   | Lock                                                                                                                                                                                                                  |



|       |         |    | This bit can only be written '1'. When this bit is set, FPEC and    |
|-------|---------|----|---------------------------------------------------------------------|
|       |         |    | FLASH_CTRL are locked. After correct unlock sequence is             |
|       |         |    | detected, this bit can be cleared by hardware. After an             |
|       |         |    | unsuccessful unlock operation, this bit cannot be modified unit the |
|       |         |    | next system reset.                                                  |
|       |         |    | Start                                                               |
| Bit 6 | RSTR    | rw | An erase operation will be triggered when this bit is set. This bit |
|       |         |    | can only be set by software, and be cleared when BSY becomes        |
|       |         |    | `0′.                                                                |
| Bit 5 | UOBERS  | rw | Option bytes erase Erase option bytes                               |
| Bit 4 | UOBPRGM | rw | Option bytes program Program option bytes                           |
| Bit 2 | CHPERS  | rw | Mass erase Select erasing all user Pages                            |
| Bit 1 | PGERS   | rw | Page erase Select erasing Pages                                     |
| Bit 0 | PRGM    | rw | Programming Select programming                                      |

#### 5.4.6 Flash Address Register (FLASH\_ADDR)

Only used in Flash memory Bank 1.

Address offset: 0x14

Reset value: 0x0000 0000

These bits are modified by hardware as the current/last address being used. In Page erase operation, this register must be modified by software to select the Pages to be erased.

| Bit      | Name | Туре | Description                                                        |
|----------|------|------|--------------------------------------------------------------------|
|          |      |      | Flash address                                                      |
|          |      |      | Select the address to be programmed in programming operation,      |
| Bit 31:0 | ТА   | w    | and select the Pages to be erased in Page erase operation.         |
|          |      |      | Note: When the BSY bit in FLASH_STS is $1'$ , this register cannot |
|          |      |      | be written.                                                        |



#### 5.4.7 Option Byte Register (FLASH\_UOB)

Address offset: 0x1C

Reset value: 0x03FF FFFC

| Bit       | Name    | Туре | Description                                                         |
|-----------|---------|------|---------------------------------------------------------------------|
| Bit 31:26 | -       | -    | Reserved. Must be kept at reset value '0'.                          |
| Bit 25:18 | USER_D1 | r    | User data 1                                                         |
| Bit 17:10 | USER_D0 | r    | User data 0                                                         |
|           |         |      | User option bytes, including user option bytes loaded with OBL Bit  |
|           |         | r    | [9: 6]: Unused<br>Bit 5: BTOPT                                      |
| Bit 9:2   | USR     |      | Bit 4: nSTDBY_RST                                                   |
|           |         |      | Bit 3: nSTP_RST                                                     |
|           |         |      | Bit 2: SYSCLKSEL_WDG                                                |
| Bit 1     | RDPRTEN | r.   | When read protection is '1', read protection to the Flash memory is |
| DICI      | RUPRIEN | r    | valid. Note: This bit is read-only.                                 |
|           |         | R r  | Option bytes error                                                  |
| Bit 0     | UOBFLR  |      | When option bytes and their opposites are mismatched, this bit is   |
|           |         |      | '1'. And the corresponding option byte is forced to 0xFF in         |
|           |         |      | FLASH_UOB and FLASH_WRPRT registers.                                |

#### 5.4.8 Write Protection Register (FLASH\_WRPRT)

Address offset: 0x20

Reset value: 0xFFFF FFFF

| Bit      | Name     | Туре | Description                                                      |  |
|----------|----------|------|------------------------------------------------------------------|--|
| Bit 31:0 | WRPRTBMP | r    | Write protection                                                 |  |
|          |          |      | This register includes write protection option bytes loaded with |  |
|          |          |      | OBL. 0: Write protection is enabled.                             |  |
|          |          |      | 1: Write protection is disabled. Note: These bits are read-only. |  |
|          |          |      |                                                                  |  |



#### 5.4.9 FPEC Key Register 2 (FLASH\_FCKEY2)

Only used in Flash memory Bank 2.

Address offset: 0x44

Reset value: xxxx xxxx

Note: All bits are write-only, and will return 0 after being read.

| Bit      | Name  | Туре  | Description                                        |
|----------|-------|-------|----------------------------------------------------|
|          | KEY W |       | FPEC key                                           |
| Bit 31:0 |       | KEY W | These bits are used for FPEC unlock key in Bank 2. |

#### 5.4.10 Flash Status Register 2 (FLASH\_STS2)

Only used in Flash memory Bank 2.

Address offset: 0x4C

| Bit      | Name     | Туре | Description                                                                                                                                                                                                     |
|----------|----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:6 | -        | -    | Reserved. Must be kept at reset value '0'.                                                                                                                                                                      |
| Bit 5    | PRCDN    | rw   | Process Done<br>When Flash memory operation (program/erase) is completed, this<br>bit is set by hardware. This bit is cleared by writing '1'.<br>Note: Every successful program or erase will set PRCDN status. |
| Bit 4    | WRPRTFLR | rw   | Write protection error<br>When programming write-protected Flash memory address, this bit<br>is set by hardware. This bit is cleared by writing `1'.                                                            |
| Bit 3    |          | -    | Reserved. Must be kept at reset value '0'.                                                                                                                                                                      |
| Bit 2    | PRGMFLR  | rw   | Programming error<br>When programming address of which the content is not '0xFFFF',<br>this bit is set by hardware. This bit is cleared by writing '1'.                                                         |



|       |     |    | Note: Before programming, the RSTR bit in FLASH_CTRL2 register     |
|-------|-----|----|--------------------------------------------------------------------|
|       |     |    | must be cleared.                                                   |
| Bit 1 | -   | -  | Reserved. Must be kept at reset value '0'.                         |
| Bit 0 | BSY | rw | Busy                                                               |
|       |     |    | This bit indicates that Flash memory operation is in process. This |
|       |     |    | bit is set when Flash memory operation starts; it is cleared when  |
|       |     |    | operation is completed or an error occurs.                         |

### 5.4.11 Flash Control Register 2 (FLASH\_CTRL2)

Only used in Flash memory Bank 2.

Address offset: 0x50

| Bit        | Name    | Туре | Description                                                                                                                                                                                                    |
|------------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:13  | -       | -    | Reserved. Must be kept at reset value '0'.                                                                                                                                                                     |
| Bit 12     | PRCDNIE | rw   | Process done interrupt enable<br>This bit enables interrupt when the PRCDN bit in FLASH_STS2<br>register becomes '1'.<br>0: Interrupt is disabled;<br>1: Interrupt is enabled.                                 |
| Bit 11,9,8 | -       | -    | Reserved. Must be kept at reset value '0'.                                                                                                                                                                     |
| Bit 10     | ERRIE   | rw   | Error status interrupt enable<br>This bit enables interrupt when FPEC errors occur. (When the<br>PRGMFLR/WRPRTFLR bit in FLASH_STS2 register is set.)<br>0: Interrupt is disabled;<br>1: Interrupt is enabled. |
| Bit 7      | LOCK    | rw   | Lock<br>This bit can only be written '1'. When this bit is set, FPEC and<br>FLASH_CTRL2 are locked. After correct unlock sequence is<br>detected, this bit can be cleared by hardware. After an                |



|         |        |      | unsuccessful unlock operation, this bit cannot be modified unit the          |  |
|---------|--------|------|------------------------------------------------------------------------------|--|
|         |        |      | next system reset.                                                           |  |
|         |        |      | Start<br>An erase operation will be triggered when this bit is set. This bit |  |
| Bit 6   | RSTR   | rw   | can only be set by software, and be cleared when BSY becomes                 |  |
|         |        |      | <sup>`</sup> 0′.                                                             |  |
| Bit 5:3 | -      | -    | Reserved. Must be kept at reset value '0'.                                   |  |
| Bit 2   | CHPERS | rw   | Mass erase                                                                   |  |
|         |        | 1 VV | Select erasing all user Pages.                                               |  |
| Bit 1   | PGERS  | rw   | Page erase Select erasing Pages.                                             |  |
| Bit 0   | PRGM   | rw   | Programming Select programming.                                              |  |

#### 5.4.12 Flash Address Register 2 (FLASH\_ADDR2)

Only used in Flash memory Bank 2.

Address offset: 0x54

Reset value: 0x0000 0000

These bits are modified by hardware as the current/last address being used. In Page erase operation, this register must be modified by software to select the Pages to be erased.

| Bit      | Name | Туре | Description                                                       |  |
|----------|------|------|-------------------------------------------------------------------|--|
|          |      |      | Flash address                                                     |  |
|          |      |      | Select the address to be programmed in programming operation,     |  |
| Bit 31:0 | ТА   | w    | and select the Pages to be erased in Page erase operation.        |  |
|          |      |      | Note: When the BSY bit in FLASH_STS2 is `1', this register cannot |  |
|          |      |      | be written.                                                       |  |

#### 5.4.13 FPEC Key Register 3 (FLASH\_FCKEY3)

Only used in Flash memory Bank 3.

Address offset: 0x84



#### Reset value: xxxx xxxx

| Bit      | Name | Туре | Description                                                    |  |
|----------|------|------|----------------------------------------------------------------|--|
| Bit 31:0 | KEY  | w    | FPEC key<br>These bits are used for FPEC unlock key in Bank 3. |  |

Note: All bits are write-only, and will return 0 after being read.

#### 5.4.14 Flash Option Byte Register (FLASH\_SELECT)

Only used in Flash memory Bank 3.

Address offset: 0x88

Reset value: 0x0000 0000

| Bit      | Name         | Туре | Description                                                      |  |
|----------|--------------|------|------------------------------------------------------------------|--|
|          |              | w    | Bank 3 supports extended SPI Flash chip models selection         |  |
|          |              |      | 0x0001: GD25Q127C, GD25Q64C, GD25Q32C, GD25Q16C,                 |  |
|          | SELECT[31:0] |      | GD25Q80C                                                         |  |
| Bit 31:0 |              |      | 0x0002: EN25F20A, EN25QH128A, W25Q128V                           |  |
| ЫС 51:0  | SELCT[51.0]  |      | Others: Reserved                                                 |  |
|          |              |      | Note: In addition to the above SPI Flash models, SPI Flash chips |  |
|          |              |      | compatible with the above models' instruction sets are also      |  |
|          |              |      | supported.                                                       |  |

#### 5.4.15 Flash Status Register 3 (FLASH\_STS3)

Only used in Flash memory Bank 3.

Address offset: 0x8C

| Bit      | Name | Туре | Description                                |  |
|----------|------|------|--------------------------------------------|--|
| Bit 31:6 | -    | -    | Reserved. Must be kept at reset value '0'. |  |



| Bit 5 | PRCDN    | rw | Process Done                                                       |  |  |  |
|-------|----------|----|--------------------------------------------------------------------|--|--|--|
|       |          |    | When Flash memory operation (program/erase) is completed, this     |  |  |  |
|       |          |    | bit is set by hardware. This bit is cleared by writing `1'.        |  |  |  |
|       |          |    | Note: Every successful program or erase will set PRCDN status.     |  |  |  |
| Bit 4 | WRPRTFLR | rw | Write protection error                                             |  |  |  |
|       |          |    | When programming write-protected Flash memory address, this bit    |  |  |  |
|       |          |    | is set by hardware. This bit is cleared by writing '1'.            |  |  |  |
| Bit 3 | -        | -  | Reserved. Must be kept at reset value '0'.                         |  |  |  |
| Bit 2 | PRGMFLR  | rw | Programming error                                                  |  |  |  |
|       |          |    | When programming address of which the content is not `0xFFFF',     |  |  |  |
|       |          |    | this bit is set by hardware. This bit is cleared by writing '1'.   |  |  |  |
|       |          |    | Note: Before programming, the RSTR bit in FLASH_CTRL3 register     |  |  |  |
|       |          |    | must be cleared.                                                   |  |  |  |
| Bit 1 | -        | -  | Reserved. Must be kept at reset value '0'.                         |  |  |  |
| Bit 0 | BSY      | r  | Busy                                                               |  |  |  |
|       |          |    | This bit indicates that Flash memory operation is in process. This |  |  |  |
|       |          |    | bit is set when Flash memory operation starts; it is cleared when  |  |  |  |
|       |          |    | operation is completed or an error occurs.                         |  |  |  |

#### 5.4.16 Flash Control Register 3 (FLASH\_CTRL3)

Only used in Flash memory Bank 3.

Address offset: 0x90

| Bit            | Name    | Туре                      | Description                                                 |  |
|----------------|---------|---------------------------|-------------------------------------------------------------|--|
| Bit 31:13      | -       | -                         | Reserved. Must be kept at reset value '0'.                  |  |
|                |         | RCDNIE rw                 | Process done interrupt enable                               |  |
|                | DRCDNIE |                           | This bit enables interrupt when the PRCDN bit in FLASH_STS3 |  |
| Bit 12 PRCDNIE | PRCDNIE |                           | register becomes `1'.                                       |  |
|                |         | 0: Interrupt is disabled; |                                                             |  |



|               |        |    | 1: Interrupt is enabled.                                                                                                                                                                                                                                                                     |  |  |  |
|---------------|--------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit<br>11,9,8 | -      | -  | Reserved. Must be kept at reset value '0'.                                                                                                                                                                                                                                                   |  |  |  |
| Bit 10        | ERRIE  | rw | Error status interrupt enable<br>This bit enables interrupt when FPEC errors occur. (When the<br>PRGMFLR/WRPRTFLR<br>bit in FLASH_STS3 register is set.)<br>0: Interrupt is disabled;<br>1: Interrupt is enabled.                                                                            |  |  |  |
| Bit 7         | LOCK   | rw | Lock<br>This bit can only be written '1'. When this bit is set, FPEC and<br>FLASH_CTRL3 are locked. After correct unlock sequence is<br>detected, this bit can be cleared by hardware. After an<br>unsuccessful unlock operation, this bit cannot be modified unit the<br>next system reset. |  |  |  |
| Bit 6         | RSTR   | rw | Start<br>An erase operation will be triggered when this bit is set. This bit<br>can only be set by software, and be cleared when BSY becomes<br>'0'.                                                                                                                                         |  |  |  |
| Bit 5:3       | -      | -  | Reserved. Must be kept at reset value '0'.                                                                                                                                                                                                                                                   |  |  |  |
| Bit 2         | CHPERS | rw | Mass erase Select erasing all user Pages                                                                                                                                                                                                                                                     |  |  |  |
| Bit 1         | PGERS  | rw | Page erase Select erasing Pages                                                                                                                                                                                                                                                              |  |  |  |
| Bit 0         | PRGM   | rw | Programming Select programming                                                                                                                                                                                                                                                               |  |  |  |

#### 5.4.17 Flash Address Register 3 (FLASH\_ADDR3)

Only used in Flash memory Bank 3.

Address offset: 0x94

Reset value: 0x0000 0000

These bits are modified by hardware as the current/last address being used. In Page erase operation, this



| register must | be modified by | software to | select the | Pages to | be erased. |
|---------------|----------------|-------------|------------|----------|------------|
|               |                |             |            |          |            |

| Bit      | Name | Туре | Description                                                         |  |  |
|----------|------|------|---------------------------------------------------------------------|--|--|
|          |      |      | Flash address                                                       |  |  |
|          |      |      | Select the address to be programmed in programming operation,       |  |  |
| Bit 31:0 | ТА   | w    | and select the Pages to be erased in Page erase operation.          |  |  |
|          |      |      | Note: When the BSY bit in FLASH_STS3 is $1'$ , this register cannot |  |  |
|          |      |      | be written.                                                         |  |  |

#### 5.4.18 Flash Decode Address Register (FLASH\_DA)

Only used in Flash memory Bank 3.

Address offset: 0x98

| Bit      | Name         | Туре | Description                                                        |  |  |
|----------|--------------|------|--------------------------------------------------------------------|--|--|
|          |              |      | The FLASH_DA register needs to be set in the user program to set   |  |  |
|          |              |      | the block 3 encryption range.                                      |  |  |
|          |              |      | $0x0840_0000 \sim (0x0840_0000+FDA-0x1)$ is the block 3 encryption |  |  |
|          |              | w    | range memory (0x0840_0000 +FDA) $\sim$ 0x087F_FFFF is the          |  |  |
| Bi+ 21.0 | Bit 31:0 FDA |      | unencrypted range of the third flash memory (V8411N)               |  |  |
| DIC 31.0 |              |      | $(0x0840_0000 + FDA) \sim 0x093F$ FFFF is the unencrypted range of |  |  |
|          |              |      | the external memory (V8410C)                                       |  |  |
|          |              |      | Note:                                                              |  |  |
|          |              |      | When the BSY bit in FLASH_STS3 is $1'$ , this register cannot be   |  |  |
|          |              |      | written. The setting value must be a multiple of 4.                |  |  |

| Bit      | Name       | Туре | Description                               |
|----------|------------|------|-------------------------------------------|
|          |            | w    | 0xA35F_6D24                               |
| Bit 31:0 | 0 SLIB_KEY |      | These bits are used for SLIB unlock keys. |



# 5.4.19 Flash Memory CRC Calibration Control Register (CRC\_DR)

Only used in Flash Memory/Main Memory block1 and block2

Address offset: 0xF4

Reset value: 0x0000 0000

Note: All these bits are write-only, reading them has no effect.

| Bit       | Name                 | Туре | Description                                                                                                                                                                 |
|-----------|----------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31    | CRC_START            | w    | Start CRC Calibration<br>Set this bit to start user code or SLIB code CRC calibration<br>After hardware enables CRC calibration, this bit will be<br>automatically cleared. |
| Bit 30:24 | -                    | -    | Reserved. Must be kept as cleared value '0'.                                                                                                                                |
| Bit 23:12 | CRC_Page_NUM[11:0]   | w    | CRC Calibration Page Number Set the number of the CRC calibration in Pages                                                                                                  |
| Bit 11:0  | CRC_START_Page[11:0] | w    | CRC Calibration Start Page Set the start Page for this CRC<br>calibration<br>0x0: Page 0<br>0x1: Page 1<br>                                                                 |

# 5.4.20 Flash Memory CRC Calibration Result Register (CRC\_OUTR)

Only used in Main Memory or Security Library.

Address offset: 0xF8

Reset value: 0x0000 0000

Note: All these bits are read-only, writing them has no effect.

| Bit | Name |
|-----|------|
|-----|------|

Туре

Description



| В | it 31:0 | CRC_OUT | r | CRC calibration result |
|---|---------|---------|---|------------------------|
|---|---------|---------|---|------------------------|



## 6 CRC Calculation Unit (CRC)

## 6.1 CRC Introduction

The Cyclic Redundancy Check (CRC) calculation unit is used to calculate a 32-bit CRC code based on a fixed generator polynomial. In other applications, CRC-based techniques are applied to verify the correctness and integrity of data transmission or data storage. EN/IEC 60335-1 standard provides a method to verify the Flash memory integrity. The CRC calculation unit can compute a signature of the software during runtime, compare it with a reference signature generated at linktime, and finally store it at a given memory location.

### 6.2 CRC Main Features

- Use CRC-32 (Ethernet) polynomial: 0x4C11DB7
  - X32 + X26 + X23 + X22 + X16 + X12 + X11 + X10 + X8 + X7 + X4 + X2 + X +1
- A 32-bit data register for input/output
- CRC calculation period: 4 AHB clock cycles (HCLK)
- General-purpose 8-bit register (Can be used for temporary storage)

Figure 6-1 is the block diagram of CRC calculation unit.

Figure 6-1 Block Diagram of CRC Calculation Unit





## 6.3 CRC Function Overview

CRC calculation unit includes one 32-bit data register:

- When being written, this register is used as input register, and can receive new data to be calculated with CRC.
- When being read, it returns the last CRC calculation result. Every write operation into the data register creates a combination of the last CRC calculation result and the new one (CRC calculation is done to the whole 32-bit word, instead of byte by byte).

CPU write operation will be suspended during CRC calculation. Hence, back-to-back write or consecutive write-read operation can be done to the CRC\_DR register.

The CRC\_DR register can be reset to 0xFFFF FFFF with the RESET bit in the CRC\_CTRL register. This operation does not affect the data in the CRC\_IDR register.

## 6.4 CRC Registers

#### 6.4.1 Data Register (CRC\_DR)

Address offset: 0x00

Reset value: 0xFFFF FFFF

| Bit      | Name     | Туре | Description                                                                                                                              |
|----------|----------|------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | DR[31:0] | rw   | Data register bits<br>Used as input register when writing new data of CRC calculator.<br>Return CRC calculation results when it is read. |

#### 6.4.2 Independent Data Register (CRC\_IDR)

Address offset: 0x04

Reset value: 0xFFFF FFFF



| Bit 31:8 | -        | -  | Reserved                                                           |  |
|----------|----------|----|--------------------------------------------------------------------|--|
| Bit 7:0  | IDR[7:0] | rw | General-purpose 8-bit data register bits                           |  |
|          |          |    | These bits can be used for temporary storage of 1-byte data.       |  |
|          |          |    | CRC reset generated by the RESET bit in the CRC_CTRL register will |  |
|          |          |    | not affect this register.                                          |  |

#### 6.4.3 Control Register (CRC\_CTRL)

Address offset: 0x08

| Bit      | Name  | Туре | Description                                                                                                                                                  |  |
|----------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 31:1 | -     | -    | Reserved                                                                                                                                                     |  |
| Bit 0    | Reset | w    | RESET bit<br>Reset CRC calculation unit, set data register as 0xFFFF FFFF.<br>This bit can only be written '1', and is cleared by hardware<br>automatically. |  |



## 7 General-purpose and Alternate-function I/Os (GPIOs and AFIOs)

## 7.1 Introduction

GPIO interface includes 5 sets of general-purpose I/O ports.

Each GPIO set provides 16 general-purpose I/O pins. Each GPIO port has relevant control and configuration registers to fulfill specific functions. External interrupts on the GPIO pins also have relevant control and configuration registers in external interrupt controller. Please refer to <u>Chapter 8</u>.

GPIO ports are pin-shared with other alternate functions to obtain maximum flexibility on the given package. GPIO pins can be used as alternate functional pins by configuring relevant registers as the alternate function input and output.

Each GPIO pin can be configured by software as output (push-pull or open-drain), input (pull-up, pull-down, or non pull-up/ pull-down), or peripheral alternate function. Most GPIO pins provide digital or analog alternate functions. All GPIOs are high-current capable.

## 7.2 Main Features

- Input/output direction control
- Each pin has weak pull-up/pull-down function.
- Output push-pull/open drain enable control
- Output set/reset control
- External interrupt with programmable trigger edge in external interrupt configuration registers
- Analog input/output configuration
- Alternate function input/output configuration
- Port configuration lock



## 7.3 Function Overview

#### 7.3.1 GPIO Pin Configuration

Each GPIO port has two 32-bit configuration registers (GPIOx\_CTRLL, GPIOx\_CTRLH), two 32-bit data registers (GPIOx\_IPTDT, GPIOx\_OPTDT), a 32-bit set/reset register (GPIOx\_BSRE), a 16-bit reset register (GPIOx\_BRE), and a 32-bit locking register (GPIOx\_LOCK).

According to the specific hardware characteristics of each I/O port listed in the data sheet, each bit of GPIO interface can be configured into several modes by software.

- Input floating
- Input pull-up
- Input pull-down
- Analog
- Output open-drain
- Output push-pull
- Alternate function push-pull
- Alternate function open-drain

Each I/O port bit can be programmed flexibly. However, I/O port registers must be accessed by 32-bit words (half-word and byte access are not allowed). The GPIOx\_BSRE and GPIOx\_BRE registers allow independent read/modify access to any GPIO registers. In this way, IRQ generated between read and modify access will not cause risks.

The following figure shows the basic structure of an I/O port bit

Figure 7-1 Basic Structure of an I/O Port Bit





Figure 7-2 Basic Structure of a 5-V Tolerant I/O Port Bit



Note:  $V_{DD_{FT}}$  is specific to 5-V tolerant I/Os, and is different from  $V_{DD}$ .

#### Table 7-1 Port Bit Assignment

|                    | CONF1      | CONF0 | MDE1 | MDE0 | PxOPTDT  |        |
|--------------------|------------|-------|------|------|----------|--------|
| Configuration Mod  |            |       |      |      | Register |        |
| General-purpose    | Push-Pull  | 0     | 0    | 01   |          | 0 or 1 |
| Output             | Open-Drain | 0     | 1    | 10   |          | 0 or 1 |
| Alternate Function | Push-Pull  | 1     | 0    | 11   |          | Unused |



| Output | Open-Drain |   | 1 |    | Unused |
|--------|------------|---|---|----|--------|
|        | Analog     | 0 | 0 |    | Unused |
| Input  | Floating   | 0 | 1 |    | Unused |
|        | Pull-Down  | 1 | 0 | 00 | 0      |
|        | Pull-Up    |   | 0 |    | 1      |

#### Table 7-2 Output MODE

| MDE | Meaning                       |
|-----|-------------------------------|
| 00  | Reserved                      |
| 01  | Stronger push/pull capability |
| 10  | Moderate push/pull capability |
| 11  | Maximum push/pull capability  |

During and after reset, alternate function will not be enabled. I/O interface is configured in input floating mode (CONFx[1:0] = 01b, MDEx[1:0] = 00b).

After reset, JTAG pin is set as input pull-up or pull-down mode:

- PA15: JTDI in pull-up mode
- PA14: JTCK in pull-down mode
- PA13: JTMS in pull-up mode
- PB4: JNTRST in pull-down mode

When configured as output, the value written to the output data register (GPIOx\_ OPTDT) will be output to the corresponding I/O pin. Output driver can be used in push-pull mode or open-drain mode (when output is 0, only the N-MOS is activated).

Input data register (GPIOx\_IPTDT) collects the data on the I/O pin at every APB2 clock cycle. All GPIO pins have an internal weak pull-up and weak pull-down, which can be activated and stopped when configured as input.

When programming to individual bit in GPIOx\_OPTDT, software does not have to disable interrupts: in a single APB2 write operation, it is possible to modify only one bit or several bits. This can be achieved by writing '1' to the bit to be modified in set/reset register (GPIOx\_BSRE, reset: GPIOx\_BRE). Unselected bits will not be modified.



#### 7.3.2 External Interrupt/Wakeup Lines

All ports have external interrupt capability. To use external interrupt lines, the ports must be configured in input mode. For more information on external interrupt, please refer to Section 8.2.

### 7.3.3 Input Configuration

When I/O port is configured as input:

- Output buffer is disabled.
- Schmitt-trigger input is activated.
- Weak pull-up and pull-down resistors are connected depending on input configuration (pull-up, pull-down or floating).
- Data present on the I/O pin is sampled into the input data register every APB2 clock cycle.

• Read access to input data register can obtain I/O states. Figure 7-3 shows the input configuration of the I/O port bit.

Figure 7-3 Input Floating/Pull-up/Pull-down Configuration



Note: V<sub>DD\_FT</sub> is specific to 5-V tolerant I/Os, and is different from V<sub>DD</sub>.



#### 7.3.4 Analog Input Configuration

When I/O port is configured as analog input:

- Output buffer is disabled.
- Schmitt-trigger input is disabled, achieving zero consumption for every analog I/O pin. The

output value of Schmitt-trigger is forced to be '0'.

- Weak pull-up and pull-down resistors are disabled.
- Input data register value is '0' when being read.

Figure 7-4 shows the high impedance analog input configuration of I/O port bit:

#### Figure 7-4 High Impedance Analog Input Configuration



*Note: VDD\_FT is specific to 5-V tolerant I/Os, and is different from VDD.* 

### 7.3.5 Output Configuration

When I/O port is configured as output:

- Output buffer is enabled.
- Open-drain mode: A '0' in the output register activates N-MOS, while a '1' in the output

register leaves the port in HiZ (the P-MOS is never activated).



Push-pull mode: A '0' in the output register activates N-MOS, while a '1' in the output register activates P-MOS.

- Schmitt-trigger input is enabled.
- Weak pull-up and pull-down resistors are disabled.
- Data present on the I/O pin is sampled into the input data register every APB2 clock cycle.
- In open-drain mode, read access to input data register can obtain I/O states.
- In push-pull mode, read access to output data register can obtain the last written value.

Figure 7-5 shows the output configuration of I/O port bit.

#### Figure 7-5 Output Configuration



Note: V<sub>DD\_FT</sub> is specific to 5-V tolerant I/Os, and is different from V<sub>DD</sub>.

### 7.3.6 GPIO Locking Mechanism

Locking mechanism can freeze the I/O configuration. When LOCK is applied to a port bit, its configuration cannot be modified until the next reset.



#### 7.3.7 Alternate Function (AF)

Before using the default alternate function, the port bit configuration register must be programmed.

• For alternate input function, the port must be configured in input mode (floating, pull-up, or pull-down), and the input pin must be driven externally.

Note: Alternate function input pin can also be simulated by software. This kind of simulation can be achieved by programming to GPIO controller. In this case, a port should be set as alternate function output mode. Apparently, the corresponding pins are no longer driven externally. Instead, they are driven by software through GPIO controller.

• For alternate output function, the port must be configured in alternate function output mode (push-pull or open-drain).

• For bidirectional alternate function, the port bit must be configured in alternate function output mode (push-pull or open-drain). At this time, input driver is configured in floating input mode.

If the port is configured as alternate output function, pins are disconnected to output register, and connected to output signal of on-chip peripherals. If a GPIO pin is configured as alternate output function by software without activating the peripherals, its output will not be specified.

When I/O ports are configured as alternate function:

- Output buffer is turned ON in open-drain or push-pull configuration.
- Output buffer is driven by embedded peripheral signals (alternate function output).
- Schmitt-trigger input is activated.
- Weak pull-up and pull-down resistors are disabled.

• If pins are configured as multiple-function output, please refer to the data sheet for the priority of each alternate function.

- Data present on the I/O pin is sampled into the input data register every APB2 clock cycle.
- In open-drain mode, read access to input data register can obtain I/O states.
- In push-pull mode, read access to output data register can obtain the last written value.

Figure 7-6 shows the alternate function configuration of I/O port bit. Please refer to <u>Section 7.4</u> for more details.

A set of alternate function I/O registers allows users to remap some alternate functions to different pins.



Figure 7-6 Alternate Function Configuration



Note:  $V_{DD_{FT}}$  is specific to 5-V tolerant I/Os, and is different from  $V_{DD}$ .

To optimize the number of I/O functions of different device packages, some alternate functions can be remapped to other pins. This can be done by configuring the corresponding registers with software (Please refer to <u>Section 7.5</u>). In this case, alternate functions no longer map to their original pins.

Table 7-3 lists the pin configuration for each peripheral.

Table 7-3 Advanced Timers TMR1/8

| TMR1/8 Pin  | Configuration                  | GPIO Configuration           |
|-------------|--------------------------------|------------------------------|
|             | Input capture channel x        | Input floating               |
| TMR1/8_CHx  | Output compare channel x       | Alternate function push-pull |
| TMR1/8_CHxN | Complementary output channel x | Alternate function push-pull |
| TMR1/8_BKIN | Break input                    | Input floating               |
| TMR1/8_ETR  | External trigger timer input   | Input floating               |

Table 7-4 General-purpose Timer TMR2-5/TMR9-14



| TMRx Pin | Configuration                | GPIO Configuration           |
|----------|------------------------------|------------------------------|
|          | Input capture channel x      | Input floating               |
| TMRx_CHx | Output compare channel x     | Alternate function push-pull |
| TMRx_ETR | External trigger timer input | Input floating               |

Table 7-5 USART

| USART Pin  | Configuration                | GPIO Configuration             |
|------------|------------------------------|--------------------------------|
|            | Full duplex                  | Alternate function push-pull   |
| USARTx_TX  | Half duplex synchronous mode | Alternate function push-pull   |
| USARTx_RX  | Full duplex                  | Input floating/Input pull-up   |
|            | Half duplex synchronous mode | Unused. Can be used as a GPIO. |
| USARTx_CK  | Synchronous mode             | Alternate function push-pull   |
| USARTx_RTS | Hardware flow control        | Alternate function push-pull   |
| USARTx_CTS | Hardware flow control In     | put floating/Input pull-up     |

Table 7-6 SPI

| SPI Pin   | Configuration                             | GPIO Configuration             |
|-----------|-------------------------------------------|--------------------------------|
|           | Master                                    | Alternate function push-pull   |
| SPIx_SCK  | Slave                                     | Input floating                 |
|           | Full duplex/Master                        | Alternate function push-pull   |
|           | Full duplex/Slave                         | Input floating/Input pull-up   |
| SPIx_MOSI | Simplex bidirectional data<br>wire/Master | Alternate function push-pull   |
|           | Simplex bidirectional data wire/Slave     | Unused. Can be used as a GPIO. |
| SPIx_MISO | Full duplex/Master                        | Input floating/Input pull-up   |
|           | Full duplex/Slave                         | Alternate function push-pull   |
|           | Simplex bidirectional data<br>wire/Master | Unused. Can be used as a GPIO. |
|           | Simplex bidirectional data wire/Slave     | Alternate function push-pull   |



| SPIx_NSS |                                    | Input floating/Input pull-up/  |
|----------|------------------------------------|--------------------------------|
|          | Hardware Master/Slave              | Input pull-down                |
|          | Hardware Master/NSS output enabled | Alternate function push-pull   |
|          | Software                           | Unused. Can be used as a GPIO. |

#### Table 7-7 I<sup>2</sup>S

| I <sup>2</sup> S Pin | Configuration | GPIO Configuration             |
|----------------------|---------------|--------------------------------|
|                      | Master        | Alternate function push-pull   |
| I2Sx_WS              | Slave         | Input floating                 |
|                      | Master        | Alternate function push-pull   |
| I2Sx_CK              | Slave         | Input floating                 |
|                      | Transmitter   | Alternate function push-pull   |
| I2Sx_SD              | Receiver      | Input floating/Input pull-up   |
|                      |               | /Input pull-down               |
| I2Sx_MCLK            | Master        | Alternate function push-pull   |
|                      | Slave         | Unused. Can be used as a GPIO. |

#### Table 7-8 I<sup>2</sup>C Interface

| I <sup>2</sup> C Pin | Configuration          | GPIO Configuration            |
|----------------------|------------------------|-------------------------------|
| I2Cx_SCL             | I <sup>2</sup> C clock | Alternate function open-drain |
| I2Cx_SDA             | I <sup>2</sup> C data  | Alternate function open-drain |
| I2Cx_SMBA            | SMBUS alert            | Alternate function open-drain |

#### Table 7-9 BxCAN

| BxCAN Pin | GPIO Configuration           |
|-----------|------------------------------|
| CAN_TX    | Alternate function push-pull |
| CAN_RX    | Input floating/Input pull-up |

Table 7-10 USB

| USB Pin       | GPIO Configuration                                                    |  |
|---------------|-----------------------------------------------------------------------|--|
|               | Once the USB block is enabled, these pins are automatically connected |  |
| USB_DM/USB_DP | to the USB internal transceiver.                                      |  |



| USB_SOF        | Alternate function push-pull |  |
|----------------|------------------------------|--|
| Table 7-11 ADC |                              |  |
| ADC Pin        | GPIO Configuration           |  |

| ADC Pin | GPIO Configuration |
|---------|--------------------|
| ADC     | Analog input       |

Note: ADC input pin must be configured as analog input.

Table 7-12 XMC

| XMC Pin          | GPIO Configuration           |
|------------------|------------------------------|
| XMC_A[25:0]      |                              |
| XMC_D[15:0]      | Alternate function push-pull |
| XMC_CK           | Alternate function push-pull |
| XMC_NOE          |                              |
| XMC_NWE          | Alternate function push-pull |
| XMC_NE[4:1]      |                              |
| XMC_NCE[3:2]     | Alternate function puch pull |
| XMC_NCE4_1       | Alternate function push-pull |
| XMC_NCE4_2       |                              |
| XMC_NWAIT XMC_CD | Input floating/Input pull-up |
| XMC_NIOS16       |                              |
| XMC_INTR         | Input floating               |
| XMC_INT[3:2]     |                              |
| XMC_NL           |                              |
| XMC_NBL[1:0]     | Alternate function push-pull |
| XMC_NIORD        |                              |
| XMC_NIOWR        | Alternate function push-pull |
| XMC_NREG         |                              |

Table 7-13 Other I/O Functions

| Pin        | Alternate Function | GPIO Configuration                      |
|------------|--------------------|-----------------------------------------|
|            | RTC output         | Forced by hardware when configuring the |
| TAMPER-RTC | Tamper event input | BRKP_CTRL and BRKP_RTCCAL registers.    |



| CLKOUT Clock output |                           | Alternate function push-pull                 |  |
|---------------------|---------------------------|----------------------------------------------|--|
| EXTINT input lines  | External input interrupts | Input floating/Input pull-up/Input pull-down |  |

### 7.4 IO Mapping Function Configuration

To optimize the number of peripherals on different packages, some alternate functions can be remapped on other pins. Pin remapping can be achieved by setting the AF remap and debug I/O configuration register (AFIO\_MAPx) or AF Remap and Debug I/O Configuration Register x (AFIO\_MAPx) (x = 2, 3, ...8). In this case, alternate functions no longer map to their original assignation.

## 7.4.1 OSC32\_IN/OSC32\_OUT as GPIO Interface PC14/ PC15

When LSE oscillator is OFF, LSE oscillator pins, OSC32\_IN/OSC32\_OUT, can be used as the PC14/PC15 of GPIO. LSE function always has higher priority than general-purpose I/O port.

#### 7.4.2 CAN Alternate Function Remapping

CAN signal can be mapped to port A, port B, or port D, as shown in Table 7-16.

Refer to Multiplex Remapping and Debug I/O Configuration Register (AFIO\_MAP) or Remapping and Debug I/O Configuration Register 6 (AFIO\_MAP6).

Table 7-14 CA1 Alternate Function Remapping

| Alternate Function | CAN_REMAP[1:0] = '00' | CAN_REMAP[1:0] = `10' | CAN_REMAP[1:0] = `11' |
|--------------------|-----------------------|-----------------------|-----------------------|
|                    | or CAN1_GRMP[3:0] =   | or CAN1_GRMP[3:0] =   | or CAN1_GRMP[3:0] =   |
|                    | `0000′                | `0010 <i>′</i>        | `0011 <i>′</i>        |
| CAN_RX             | PA11                  | PB8                   | PD0                   |
| CAN_TX             | PA12                  | PB9                   | PD1                   |

### 7.4.3 JTAG/SWD Alternate Function Remapping

Debug interface signal is mapped to GPIO port, as shown in Table 7-15.

Table 7-15 Debug Interface Signal



| Alternate Function | GPIO Port |
|--------------------|-----------|
| JTMS/SWDIO         | PA13      |
| JTCK/SWCLK         | PA14      |
| JTDI               | PA15      |
| JTDO               | PB3       |
| JNTRST             | PB4       |

To use more GPIOs during debugging, configuring the SWJTAG\_CONF[2:0] bits in the AF remap and debug I/O configuration register (AFIO\_MAP) or SWJTAG\_GRMP[2:0] bits in AF remap and debug I/O configuration register 7 (AFIO\_MAP7) can modify the above-mentioned remapping configuration.

Table 7-16 Debug Port Mapping

| SWJTAG_CONF[2:0] |                          | SWJI/O Pin Assignment |            |           |                  |           |
|------------------|--------------------------|-----------------------|------------|-----------|------------------|-----------|
| or               | Possible Debug Port      | PA13/ JTMS/           | PA14/ JTCK | PA15/     |                  | PB4/      |
| SWJTAG_GRMP[2:0] |                          | SWDIO                 | /SWCLK     | JTDI      | PB3/ JTDO        | NJTRST    |
| 000              | Full SWJ (JTAG-DP+SW-    | I/O not               | I/O not    | I/O not   | I/O not          | I/O not   |
|                  | DP) (reset status)       | available             | available  | available | available        | available |
| 001              | Full SWJ (JTAG-DP+ SW-   | I/O not               | I/O not    | I/O not   | I/O not          | I/O       |
|                  | DP) Without JNTRST       | available             | available  | available | available        | available |
| 010              | Disable JTAG-DP, Enable  | I/O not               | I/O not    | I/O       | I/O<br>available | I/O       |
| 010              | SW-DP                    | available             | available  | available | (Note)           | available |
|                  | Disable JTAG-DP, Disable |                       | I/O        | I/O       | I/O              | I/O       |
| 100              | SW-DP                    | I/O available         | available  | available | available        | available |
| Other            | Forbidden                | -                     | -          | -         | -                | -         |

#### 7.4.4 ADC Alternate Function Remapping

Please refer to the AF remap and debug I/O configuration register (AFIO\_MAP) or AF remap and debug I/O configuration register 7 (A FIO\_MAP7).



| Table 7-17 ADC1 External Trigger Injected Conversion Alternate Function Remapping |                                        |                                |  |  |  |
|-----------------------------------------------------------------------------------|----------------------------------------|--------------------------------|--|--|--|
|                                                                                   | ADC1_ETI_GRMP = 0 or ADC1_ETI_GRMP = 1 |                                |  |  |  |
| Alternate Function                                                                | ADC1_EXTRGINJ_REMAP = 0                | ADC1_EXTRGINJ_REMAP = 1        |  |  |  |
|                                                                                   | ADC1 External Trigger Injected         | ADC1 External Trigger Injected |  |  |  |
| ADC1 External Trigger                                                             | Conversion is connected to             | Conversion is connected to     |  |  |  |
| Injected Conversion                                                               | EXTINT15                               | TMR8_CH4                       |  |  |  |

Table 7-18 ADC1 External Trigger Regular Conversion Alternate Function Remapping

|                       | $ADC1\_ETR\_GRMP = 0 \text{ or}$ | ADC1_ETR_GRMP = 1 or          |
|-----------------------|----------------------------------|-------------------------------|
| Alternate Function    | ADC1_EXTRGREG_REMAP = 0          | ADC1_EXTRGREG_REMAP = 1       |
| ADC1 External Trigger | ADC1 External Trigger Regular    | ADC1 External Trigger Regular |
|                       | Conversion is connected to       | Conversion is connected to    |
| Regular Conversion    | EXTINT11                         | TMR8_TRGO                     |

#### 7.4.5 Timer Alternate Function Remapping

Please refer to the AF remap and debug I/O configuration register (AFIO\_MAP), AF remap and debug I/O configuration register 2 (AFIO\_MAP2), AF remap and debug I/O configuration register 3 (AFIO\_MAP3), and AF remap and debug I/O configuration register 4 (AFIO\_MAP4).

| Table 7-19 TMR1 Alternate Function Rema |
|-----------------------------------------|
|-----------------------------------------|

|                    | TMR1_REMAP[1:0] = 00  | TMR1_REMAP[1:0] = 01  | TMR1_REMAP[1:0] = 11  |
|--------------------|-----------------------|-----------------------|-----------------------|
| Alternate Function | or                    | or                    | or                    |
| Remapping          | TMR1_GRMP[3:0] = 0000 | TMR1_GRMP[3:0] = 0001 | TMR1_GRMP[3:0] = 0011 |
|                    | (No remapping)        | (Partial remapping)   | (Full remapping)      |
| TMR1_ETR           | PA                    | 412                   | PE7                   |
| TMR1_CH1           | P                     | PE9                   |                       |
| TMR1_CH2           | PA9                   |                       | PE11                  |
| TMR1_CH3           | PA10                  |                       | PE13                  |
| TMR1_CH4           | PA11                  |                       | PE14                  |
| TMR1_BKIN          | PB12                  | PA6                   | PE15                  |
| TMR1_CH1N          | PB13                  | PA7                   | PE8                   |



| TMR1_CH2N | PB14 | PBO | PE10 |
|-----------|------|-----|------|
| TMR1_CH3N | PB15 | PB1 | PE12 |

#### Table 7-20 TMR2 Alternate Function Remapping

|              | TMR2_GRMP[2:0]=000 | TMR2_GRMP[2:0]= 001 | TMR2_GRMP[2:0]= 010 | TMR2_GRMP[2:0]=011 |
|--------------|--------------------|---------------------|---------------------|--------------------|
| Alternate    | or                 | or                  | or                  | or                 |
| Function     | TMR2_REMAP[1:0]=00 | TMR2_REMAP[1:0]=01  | TMR2_REMAP[1:0]=10  | TMR2_REMAP[1:0]=11 |
| TMR2_CH1_ETR |                    |                     | DAG                 |                    |
| (Note)       | PAO                | PA15                | PAO                 | PA15               |
| TMR2_CH2     | PA1                | PB3                 | PA1                 | PB3                |
| TMR2_CH3     | PA2                |                     | PB10                |                    |
| TMR2_CH4     | PA3                |                     | PB11                |                    |

Note: TMR2\_CH1 and TMR2\_ETR share the same pin, but cannot be used simultaneously. (Hence "TMR2\_CH1\_ETR" is used here for the expression.)

| Alternate | TMR3_GRMP[3:0] = 0000 | TMR3_GRMP[3:0] = 0010 | TMR3_GRMP[3:0] = 0011              |
|-----------|-----------------------|-----------------------|------------------------------------|
| Function  | or                    | or                    | or                                 |
|           | TMR3_REMAP[1:0] = 00  | TMR3_REMAP[1:0] = 10  | TMR3_REMAP[1:0] = 11               |
|           | (No remapping)        | (Partial remapping)   | (Full remapping) <sup>(Note)</sup> |
| TMR3_CH1  | PA6                   | PB4                   | PC6                                |
| TMR3_CH2  | PA7                   | PB5                   | PC7                                |
| TMR3_CH3  | PBO                   |                       | PC8                                |
| TMR3_CH4  | PB1                   |                       | PC9                                |

Note: Remapping only applies to 64 -pin and 100-pin packages.

Table 7-22 TMR4 Alternate Function Remapping

| Alternate Function | $TMR4_REMAP = 0 \text{ or}$ | TMR4_REMAP = 1 or    |
|--------------------|-----------------------------|----------------------|
| Mapping            | TMR4_GRMP[3:0] = 0000       | TMR4_GRMP[3:] = 0001 |
| TMR4_CH1           | PB6                         | PD12                 |
| TMR4_CH2           | РВ7                         | PD13                 |



| TMR4_CH3 | PB8 | PD14 |
|----------|-----|------|
| TMR4_CH4 | PB9 | PD15 |

Table 7-23 TMR5 Alternate Function Remapping

| Alternate Function Mapping | $TMR9\_REMAP = 0$     | TMR9_REMAP = 1        |
|----------------------------|-----------------------|-----------------------|
| TMR5 CH4                   | TMR5 Channel 4 to PA3 |                       |
|                            |                       | input for calibration |

Table 7-24 TMR9 Alternate Function Remapping

| Alternate Function TMR9_GRMP[3:0] = 0000 or |                  | TMR9_GRMP[3:0] = 0001 or |  |
|---------------------------------------------|------------------|--------------------------|--|
| Mapping                                     | $TMR9_REMAP = 0$ | $TMR9\_REMAP = 1$        |  |
| TMR9_CH1                                    | PA2              | PE5                      |  |
| TMR9_CH2                                    | PA3              | PE6                      |  |

#### 7.4.6 USART Alternate Function Remapping

Please refer to AF remap and debug I/O configuration register (AFIO\_MAP), AF remap and debug I/O configuration register 6 (AFIO\_MAP6), and AF remap and debug I/O configuration register 8 (AFIO\_MAP8).

Table 7-25 USART1 Remapping

| Alternate Function | Alternate Function USART1_GRMP[3:0] = 0000 |                     |
|--------------------|--------------------------------------------|---------------------|
|                    | or USART1_REMAP = $0$                      | or USART1_REMAP = 1 |
| USART1_TX          | PA9                                        | PB6                 |
| USART1_RX          | PA10                                       | PB7                 |

Table 7-26 USART2 Remapping

| Alternate Function | USART2_REMAP = 0           | USART2_REMAP = 1 <sup>(Note)</sup> |  |
|--------------------|----------------------------|------------------------------------|--|
|                    | or USART2_GRMP[3:0] = 0000 | or USART2_GRMP[3:0] = 0001         |  |
| USART2_CTS         | PAO                        | PD3                                |  |
| USART2_RTS         | PA1                        | PD4                                |  |
| USART2_TX          | PA2                        | PD5                                |  |
| USART2_RX          | PA3                        | PD6                                |  |



| USART2_CK PA4 PD7 |
|-------------------|
|-------------------|

Note: Remapping only applies to 100-pin package.

Table 7-27 USART3 Remapping

| Alternate  | USART3_REMAP[1:0] = 00  | USART3_REMAP[1:0] = 01  | USART3_REMAP[1:0] = 11  |
|------------|-------------------------|-------------------------|-------------------------|
| Function   | or                      | or                      | or                      |
|            | USART3_GRMP[3:0] = 0000 | USART3_GRMP[3:0] = 0001 | USART3_GRMP[3:0] = 0011 |
|            | (No remapping)          | (Partial remapping)     | (Full remapping)        |
| USART3_TX  | PB10                    | PC10                    | PD8                     |
| USART3_RX  | PB11                    | PC11                    | PD9                     |
| USART3_CK  | PB12 PC12               |                         | PD10                    |
| USART3_CTS | PB13                    |                         | PD11                    |
| USART3_RTS | PB14                    |                         | PD12                    |

Table 7-28 UART 4 Remapping

| Alternate Function | UART4_GRMP[3:0] = 0000 | UART4_GRMP[3:0] = 0010 |
|--------------------|------------------------|------------------------|
| UART4_TX           | PC10                   | PAO                    |
| UART4_RX           | PC11                   | PA1                    |

Table 7-29 UART 5 Remapping

| Alternate Function UART5_GRMP[3:0] = 0000 |      | UART5_GRMP[3:0] = 0001 |
|-------------------------------------------|------|------------------------|
| UART5_TX                                  | PC12 | PB9                    |
| UART5_RX                                  | PD2  | PB8                    |

#### Table 7-30 USART 6 Remapping

| Alternate Function | USART6_GRMP[3:0] = 0000 | USART6_GRMP[3:0] = 0001 |
|--------------------|-------------------------|-------------------------|
| USART6_TX          | PC6                     | PA4                     |
| USART6_RX          | PC7                     | PA5                     |

Table 7-31 UART 7 Remapping

| Alternate Function | UART7_GRMP[3:0] = 0000 | UART7_GRMP[3:0] = 0001 |
|--------------------|------------------------|------------------------|
| UART7_TX           | PE8                    | PB4                    |
| UART7_RX           | PE7                    | PB3                    |



Table 7-32 UART 8 Remapping

| Alternate Function | UART8_GRMP[3:0] = 0000 | UART8_GRMP[3:0] = 0001 |
|--------------------|------------------------|------------------------|
| UART8_TX           | PE1                    | PC2                    |
| UART8_RX           | PEO                    | PC3                    |

#### 7.4.7 I<sup>2</sup>C Alternate Function Remapping

Please refer to the AF remap and debug I/O configuration register (AFIO\_MAP) or AF remap and debug I/O configuration register 5 (AFIO\_MAP5).

Table 7-33 I2C1 Remapping

| Alternate Function | I2C1_REMAP = 0 or     | I2C1_REMAP = 1 or     |
|--------------------|-----------------------|-----------------------|
|                    | I2C1_GRMP[3:0] = 0000 | I2C1_GRMP[3:0] = 0001 |
| I2C1_SCL           | PB6                   | PB8                   |
| I2C1_SDA           | PB7                   | PB9                   |
| I2C1_SMBA          | PB5                   |                       |

Table 7-34 I2C3 Remapping

| Alternate Function | I2C3_REMAP = 0 or I2C3_REMAP = 1 or I2C3_GRMP[3:0] |        |
|--------------------|----------------------------------------------------|--------|
|                    | I2C3_GRMP[3:0] = 0000                              | = 0001 |
| I2C3_SCL           |                                                    | PA8    |
| I2C3_SDA           | PC9                                                | PB4    |
| I2C3_SMBA          |                                                    | PA9    |

#### 7.4.8 SPI/ I2S Alternate Function Remapping

Please refer to the AF remap and debug I/O configuration register (AFIO\_MAP) or AF remap and debug I/O configuration register 5 (AFIO\_MAP5).

Table 7-35 SPI1/I2S1 Remapping

| Alternate Function | SPI1_GRMP[3:0]  | SPI1_GRMP[3:0]  | SPI1_GRMP[3:0] = | SPI1_GRMP[3:0] = |
|--------------------|-----------------|-----------------|------------------|------------------|
|                    | = 0000 or       | = 0001 or       | 0010 or          | 0011 or          |
|                    | SPI1_REMAP[1:0] | SPI1_REMAP[1:0] | SPI1_REMAP[1: 0] | SPI1_REMAP[1:0]  |



|                   | = 00 | = 01 | = 10 | = 11 |
|-------------------|------|------|------|------|
| SPI1_NSS/I2S1_WS  | PA4  | PA15 | PA4  | PA15 |
| SPI1_SCK/I2S1_CK  | PA5  | PB3  | PA5  | PB3  |
| SPI1_MISO         | PA6  | PB4  | PA6  | PB4  |
| SPI1_MOSI/I2S1_SD | PA7  | PB5  | PA7  | PB5  |
| I2S1_MCLK         | F    | °B0  | PI   | 36   |

Table 7-36 SPI2/I2S2 Remapping

| Alternate Function | SPI2_GRMP[3:0] = 0000 | SPI2_GRMP[3:0] = 0001 | SPI2_GRMP[3:0] = 0010 |
|--------------------|-----------------------|-----------------------|-----------------------|
| I2S2_MCLK          | PC6                   | РАЗ                   | PA6                   |

Table 7-37 SPI3/I2S3 Remapping

| Alternate Function | SPI3_REMAP = 0   | SPI3_REMAP = 1   | SPI3_GRMP[3:0] = | SPI3_GRMP[3:0] = |
|--------------------|------------------|------------------|------------------|------------------|
|                    | SPI3_GRMP[3:0] = | SPI3_GRMP[3:0] = | 0010             | 0011             |
|                    | 0000             | 0001             |                  |                  |
| SPI3_NSS/I2S3_WS   | PA15             | PA4              | PA15             | PA4              |
| SPI3_SCK/I2S3_CK   | PB3              | PC10             | PB3              | PC10             |
| SPI3_MISO          | PB4              | PC11             | PB4              | PC11             |
| SPI3_MOSI          | PB5              | PC12             | PB5              | PC12             |
| I2S3_MCLK          | PC7              |                  | PE               | 310              |

Table 7-38 SPI4/I2S4 Remapping

| Alternate Function | SPI4_REMAP = 0   | SPI4_REMAP = 1    | SPI4_GRMP[3:0] = | SPI4_GRMP[3:0] = |
|--------------------|------------------|-------------------|------------------|------------------|
|                    | or               | or SPI4_GRMP[3:0] | 0010             | 0011             |
|                    | SPI4_GRMP[3:0] = | = 0001            |                  |                  |
|                    | 0000             |                   |                  |                  |
| SPI4_NSS/I2S4_WS   | PE4              | PE12              | Р                | B6               |
| SPI4_SCK/I2S4_CK   | PE2              | PE11              | Р                | B7               |
| SPI4_MISO/         | PE5              | PE13              | Р                | B8               |
| SPI4_MOSI/I2S4_SD  | PE6              | PE14              | Р                | B9               |
| I2S4_MCLK          |                  | PC8 PA            |                  | PA10             |



 $XMC_GRMP[2:0] =$ 

010

PC2

#### 7.4.9 XMC Alternate Function Remapping

Please refer to the AF remap and debug I/O configuration register 7 (AFIO\_MAP7)

|                    | 11 5                |                 |
|--------------------|---------------------|-----------------|
| Alternate Function | XMC_GRMP[2:0] = 000 | XMC_GRMP[2:0] = |
|                    |                     | 001             |
| XMC_NWE            | PD5                 | PD2             |

Table 7-39 XMC Alternate Function Remapping

| XMC_D0   | PD14 | PB14 |  |
|----------|------|------|--|
| XMC_D1   | PD15 | PC6  |  |
| XMC_D2   | PD0  | PC11 |  |
| XMC_D3   | PD1  | PC12 |  |
| XMC_D4   | PE7  | PA2  |  |
| XMC_D5   | PE8  | PA3  |  |
| XMC_D6   | PE9  | PA4  |  |
| XMC_D7   | PE10 | PA5  |  |
| XMC_D13  | PD8  | PB12 |  |
| FSMC_NOE | PD4  | PC5  |  |

### 7.5 GPIO and AFIO Registers

Note: Before read and write access to the AFIO\_EVCTRL, AFIO\_MAP, and AFIO\_EXTICRX registers, AFIO clock should be ON first. Please refer to <u>Section 3.3.7</u>.

## 7.5.1 Port Configuration Register Low (GPIOx\_CTRLL) (x = A...E)

Address offset: 0x00

| Bit | Name | Туре | Description                    |           |
|-----|------|------|--------------------------------|-----------|
|     |      |      | gzhou Vango Technologies, Inc. | 162 / 782 |

|           |            | 1            |                                                                  |
|-----------|------------|--------------|------------------------------------------------------------------|
|           |            |              | Portx configuration bit y (y = $07$ )                            |
|           |            |              | Set by software to configure the corresponding I/O ports. Please |
| D:+ 21,20 |            |              | refer to Table 7-1 for port bit configuration.                   |
| Bit 31:30 |            |              | In input mode (MDE[1:0] = 00):                                   |
| 27:26     |            |              | 00: Analog mode                                                  |
| 23:22     |            |              | 01: Floating input (Reset state)                                 |
| 19:18     | CONFy[1:0] | rw           | 10: Input with pull-up/pull-down                                 |
| 15:14     |            |              | 11: Reserved                                                     |
| 11:10     |            |              | In output mode (MDE[1:0] > 00):                                  |
| 7:6       |            |              | 00: General-purpose output push-pull                             |
| 3:2       |            |              | 01: General-purpose output open-drain                            |
|           |            |              | 10: Alternate function output push-pull                          |
|           |            |              | 11: Alternate function output open-drain                         |
|           |            |              | MDEy[1:0]: Portx Mode bit y (y = $07$ )                          |
|           |            |              | Set by software to configure the corresponding I/O ports. Please |
| Bit 29:28 |            |              | refer to Table 7-1 for port bit configuration.                   |
| 25:24     |            |              | 00: Input mode (state after reset)                               |
| 21:20     |            |              | 01: Output mode; stronger sourcing/sinking strength (Typical     |
| 17:16     | rw         | rw           | value: 6 mA)                                                     |
| 13:12     |            |              | 10: Output mode; moderate sourcing/sinking strength (Typical     |
| 9:8,5:4   |            | value: 4 mA; |                                                                  |
| 1:0       |            |              | recommended, applicable for GPIO frequency below 50 MHz)         |
|           |            |              | 11: Output mode; moderate sourcing/sinking strength (Typical     |
|           |            |              | value: 15 mA)                                                    |
| L         | I          | 1            |                                                                  |

*Note: Some port registers have different reset values. For example, some pins of PA are JTAG/SWD input with pull-up by default.* 

# 7.5.2 Port Configuration Register High (GPIOx\_CTRLH) (A...E)

Address offset: 0x04



| Bit       | Name         | Туре | Description                                                      |
|-----------|--------------|------|------------------------------------------------------------------|
|           |              |      | Portx configuration bit y (y = $815$ )                           |
|           |              |      | Set by software to configure the corresponding I/O ports. Please |
| Bit 31:30 |              |      | refer to Table 7-1 for port bit configuration.                   |
| 27:26     |              |      | In input mode (MDE[1:0] = 00):                                   |
| 23:22     |              |      | 00: Analog mode                                                  |
| 19:18     |              |      | 01: Floating input (Reset state)                                 |
| 15:14     | CONFy[1:0]   | rw   | 10: Input with pull-up/pull-down                                 |
| 11:10     |              |      | 11: Reserved                                                     |
| 7:6       |              |      | In output mode (MDE[1:0] > 00):                                  |
| 3:2       |              |      | 00: General-purpose output push-pull                             |
| 5.2       |              |      | 01: General-purpose output open-drain                            |
|           |              |      | 10: Alternate function output push-pull                          |
|           |              |      | 11: Alternate function output open-drain                         |
| Bit 29:28 |              |      |                                                                  |
| 25:24     |              |      | Portx Mode bit y (y = $815$ )                                    |
| 21:20     | MDEy[1:0] rw |      | Set by software to configure the corresponding I/O ports. Please |
| 17:16     |              |      | refer to Table 7-1 for port bit configuration.                   |
| 13:12     |              | rw   | 00: Input mode (Reset state)                                     |
| 9:8       |              |      | 01: Output mode, stronger sourcing/sinking strength              |
| 5:4       |              |      | 10: Output mode, moderate sourcing/sinking strength              |
| 1:0       |              |      | 11: Output mode, moderate sourcing/sinking strength              |

Note: Some port registers have different reset values. For example, some pins of PB are JTAG/SWD input with pull-up by default.

# 7.5.3 Port Input Data Register (GPIOx\_IPTDT) (x = A...E)

Address offset: 0x08

Reset value: 0x0000XXXX

| Bit  | Name | Туре | Description                    |           |
|------|------|------|--------------------------------|-----------|
| Mang | 10   | Han  | gzhou Vango Technologies, Inc. | 164 / 782 |

| Bit 31:16 | -            | - | Reserved. Always read as 0.                                      |
|-----------|--------------|---|------------------------------------------------------------------|
| Bit 15:0  | IPTDTy[15:0] | r | Port input data (y = 015)                                        |
|           |              |   | These bits are read-only and can be read only by word (16 bits). |
|           |              |   | The value read is the status of the corresponding I/O port.      |

# 7.5.4 Port Output Data Register (GPIOx\_OPTDT) (x = A...E)

Address offset: 0x0C

Reset value: 0x0000000

| Bit       | Name         | Туре | Description                                                      |
|-----------|--------------|------|------------------------------------------------------------------|
| Bit 31:16 | -            | -    | Reserved. Always read as 0.                                      |
| Bit 15:0  | OPTDTy[15:0] | rw   | Port output data ( $y = 015$ )                                   |
|           |              |      | These bits can be read or written, and are accessed only by word |
|           |              |      | (16 bits).                                                       |
|           |              |      | Note: For GPIOx_BSRE (x = AE), each OPTDT bit can be             |
|           |              |      | set/reset individually.                                          |

# 7.5.5 Port Bit Set/Reset Register (GPIOx\_BSRE) (x = A...E)

Address offset: 0x10

| Bit 31:16BREyWPortx Reset bit y (y = 015)<br>These bits are write-only and are accessed only by word (16<br>bits).<br>0: No action to the corresponding OPTDTy bits.<br>1: Reset the corresponding OPTDTy bit.<br>Note: If both the corresponding bits of BSTy and MREy are set, | Bit       | Name | Туре | Description                                                                                                                                                                                    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                  | Bit 31:16 | BREy | w    | <ul> <li>These bits are write-only and are accessed only by word (16 bits).</li> <li>0: No action to the corresponding OPTDTy bits.</li> <li>1: Reset the corresponding OPTDTy bit.</li> </ul> |



|          |      |                              | the BSTy bit has higher priority.                           |
|----------|------|------------------------------|-------------------------------------------------------------|
|          |      | Portx Set bit y (y = $015$ ) |                                                             |
|          |      |                              | These bits are write-only and are accessed only by word (16 |
| Bit 15:0 | BSTy | w                            | bits).                                                      |
|          |      |                              | 0: No action to the corresponding OPTDTy bits.              |
|          |      |                              | 1: Set the corresponding OPTDTy bit.                        |

### 7.5.6 Port Bit Reset Register (IOx\_BRE) (x = A...E)

Address offset: 0x14

Reset value: 0x0000000

| Bit       | Name | Туре | Description                                                                                                                                                                                                                          |
|-----------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | -    | -    | Reserved                                                                                                                                                                                                                             |
| Bit 15:0  | BREy | w    | <ul> <li>Portx Reset bit y (y = 015)</li> <li>These bits are write-only and are accessed only by words (16 bits).</li> <li>0: No action to the corresponding OPTDTy bits.</li> <li>1: Reset the corresponding OPTDTy bit.</li> </ul> |

## 7.5.7 Port Configuration Lock Register (GPIOx\_LOCK) (x = A...E)

When Bit 16 (LOCKK) is written with the correct sequence, this register is used to lock the configuration of port bit. Bit[15:0] is used to lock GPIO port configuration. During the specified write operation, LOCK[15:0] cannot be modified. After the corresponding port bit is written with LOCK sequence, the configuration of port bit cannot be modified before the next reset.

Each lock bit locks the corresponding 4 bits of the control register (CTRLL, CTRLH).

Address offset: 0x18

| Bit  | Name       | Туре | Description                    |           |
|------|------------|------|--------------------------------|-----------|
| Mang | <u> 70</u> | Han  | gzhou Vango Technologies, Inc. | 166 / 782 |

| Bit 31:17 | -     | -  | Reserved                                                           |  |
|-----------|-------|----|--------------------------------------------------------------------|--|
| Bit 16    | LOCKK | rw | Lock key                                                           |  |
|           |       |    | This bit can be read anytime, and is modified only by writing the  |  |
|           |       |    | lock key sequence.                                                 |  |
|           |       |    | 0: Port configuration lock key is not activated.                   |  |
|           |       |    | 1: Port configuration lock key is activated, and the GPIOx_LOCK    |  |
|           |       |    | register is locked before the next reset.                          |  |
|           |       |    | Lock key writing sequence:                                         |  |
|           |       |    | Write 1-> Write 0-> Write 1-> Read 0-> Read 1                      |  |
|           |       |    | The last read operation is optional, but it can be used to confirm |  |
|           |       |    | that the lock key is activated.                                    |  |
|           |       |    | Note: During the lock key writing sequence, the value of           |  |
|           |       |    | LCK[15:0] cannot be changed. Any errors in the lock key writing    |  |
|           |       |    | sequence will fail the lock key activation.                        |  |
| Bit 15:0  | LOCKy | rw | Portx Lock bit y (y = $015$ )                                      |  |
|           |       |    | These bits can be read and written, but they can be written only   |  |
|           |       |    | when the LOCKK bit is 0.                                           |  |
|           |       |    | 0: Port configuration is not locked.                               |  |
|           |       |    | 1: Port configuration is locked.                                   |  |

# 7.5.8 Slew Rate Control Register (GPIOx\_SRCTR) (x = A...E)

Address offset: 0x20

| Bit       | Name   | Туре | Description                         |  |
|-----------|--------|------|-------------------------------------|--|
| Bit 31:16 | -      | -    | Reserved                            |  |
| Bit 15:0  | SRCTRy | rw   | Port x Slew Rate bit y (y = $015$ ) |  |
|           |        |      | 0: Moderate slew rate               |  |
|           |        |      | 1: Increased slew rate              |  |



# 7.5.9 Port Huge Driven Control Register (GPIOx\_HDRV)(x = A...E)

Address offset: 0x3C

Reset value: 0x0000000

| Bit 31:16 | -     | -  | Reserved                                                                                                                                                                                                          |
|-----------|-------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0  | HDRVy | rw | <ul> <li>Port x Huge Driven bit y (y = 0 15)</li> <li>0: GPIO is configured as moderate driven, determined by</li> <li>MDEy[1:0].</li> <li>1: GPIO is configured as huge driven; MDEy[1:0] is ignored.</li> </ul> |

### 7.5.10 Alternate Event Control Register (AFIO\_EVCTRL)

Address offset: 0x00

| Bit      | Name      | Туре | Description                                                                                                                                                                                                 |  |
|----------|-----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 31:8 | -         | -    | Reserved                                                                                                                                                                                                    |  |
| Bit 7    | EVOEN     | rw   | Event output enable<br>This bit can be read and written by software. After setting this<br>bit, the EVENTOUT of Cortex <sup>®</sup> -M4 will connect to the I/O port<br>selected by PORT[2:0] and PIN[3:0]. |  |
| Bit 6:4  | PORT[2:0] | rw   | Port selection<br>Used to select the port for Cortex <sup>®</sup> EVENTOUT signal output:<br>000: Select PA<br>001: Select PB<br>010: Select PC<br>011: Select PD<br>100: Select PE                         |  |
| Bit 3:0  | PIN[3:0]  | rw   | Pin selection ( $x = AE$ )                                                                                                                                                                                  |  |



|  | Used to select the pin for Cortex EVENTOUT signal output: |
|--|-----------------------------------------------------------|
|  | 0000: Select Px0                                          |
|  | 0001: Select Px1                                          |
|  | 0010: Select Px2                                          |
|  | 0011: Select Px3                                          |
|  | 0100: Select Px4                                          |
|  | 0101: Select Px5                                          |
|  | 0110: Select Px6                                          |
|  | 0111: Select Px7                                          |
|  | 1000: Select Px8                                          |
|  | 1001: Select Px9                                          |
|  | 1010: Select Px10                                         |
|  | 1011: Select Px11                                         |
|  | 1100: Select Px12                                         |
|  | 1101: Select Px13                                         |
|  | 1110: Select Px14                                         |
|  | 1111: Select Px15                                         |

## 7.5.11 AF Remap and Debug I/O Configuration Register (AFIO\_MAP)

Address offset: 0x04

| Bit       | Name          | Туре | Description                                                                                                                                                                                                        |
|-----------|---------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31    | SPI1_REMAP[1] | rw   | SPI1 remapping<br>Specify the reference bit 0 of SPI1_REMAP[1:0].                                                                                                                                                  |
| Bit 30:29 | -             | -    | Reserved                                                                                                                                                                                                           |
| Bit 28    | SPI3_REMAP    | rw   | <ul> <li>SPI3 remapping</li> <li>Set and cleared by software. It controls the SPI3 NSS,</li> <li>SCK, MISO, and MOSI remapping to GPIO port.</li> <li>0: No remapping (NSS/PA15, SCK/PB3, MISO/PB4, and</li> </ul> |



|           |                   |    | MOSI/PB5)                                                       |
|-----------|-------------------|----|-----------------------------------------------------------------|
|           |                   |    | 1: Remapping (NSS/PA4, SCK/PC10, MISO/PC11, and                 |
|           |                   |    | MOSI/PC12)                                                      |
|           |                   |    | Note: This bit is effective only in connectivity devices; it    |
|           |                   |    | is reserved bit in other devices.                               |
| Bit 27    | -                 | -  | Reserved                                                        |
|           |                   |    | Serial wire JTAG configuration                                  |
|           |                   |    | Only be written by software (reading these bits will            |
|           |                   |    | return undefined values), and are used to configure             |
|           |                   |    | SWJ I/O ports of alternate functions. SWJ (Serial Wire          |
|           |                   |    | JTAG) supports JTAG or SWD access to the ${\sf Cortex}^{\sf R}$ |
|           |                   |    | debug port. The default state after system reset is SWJ         |
| Bit 26:24 |                   |    | ON. In this case, JTAG or SYSCLKSEL (serial wire) mode          |
| DIL 20:24 | SWJTAG_CONF[2:0]  | rw | can be selected with specific signal on the JTMS/JTCK           |
|           |                   |    | pin.                                                            |
|           |                   |    | 000: Full SWJ (JTAG-DP+SW-DP): Reset state                      |
|           |                   |    | 001: Full SWJ (JTAG-DP+SW-DP) but without NJTRST                |
|           |                   |    | 010: Disable JTAG-DP, enable SW-DP                              |
|           |                   |    | 100: Disable JTAG-DP, disable SW-DP                             |
|           |                   |    | Other combinations: No effect                                   |
| Bit 23:19 | -                 | -  | Reserved                                                        |
|           |                   |    | ADC1 external trigger regular conversion remapping Set          |
|           |                   |    | and cleared by software. It controls the trigger input          |
|           |                   |    | connected to ADC1 external trigger regular conversion.          |
| Bit 18    | ADC1_EXTRGREG_RE  | rw | When it is cleared, ADC1 external trigger regular               |
|           | МАР               |    | conversion is connected to EXTINT11; when it is set,            |
|           |                   |    | ADC1 external trigger regular conversion is connected to        |
|           |                   |    | TMR8_TRGO.                                                      |
|           |                   |    | ADC1 external trigger injected conversion remapping             |
| Bit 17    | ADC1_EXTRGINJ_REM | rw | Set and cleared by software. It controls the trigger input      |
|           | AP                |    | connected to ADC1 external trigger injected conversion.         |
|           |                   |    |                                                                 |



| -         |                | I  |                                                              |
|-----------|----------------|----|--------------------------------------------------------------|
|           |                |    | When it is cleared, ADC1 external trigger injected           |
|           |                |    | conversion is connected to EXTINT15; when it is set, ADC1    |
|           |                |    | external trigger injected conversion is connected to TMR8    |
|           |                |    | channel 4.                                                   |
|           |                |    | TMR5 channel4 internal remapping                             |
|           |                |    | Set and cleared by software. It controls TMR5 channel 4      |
|           |                |    | internal mapping. When it is cleared, TMR5_CH4 is            |
| Bit 16    | TMR5CH4_INTLRE | rw | connected to PA3; when it is set, LSI internal oscillator is |
|           |                |    | connected to TMR5_CH4, with the purpose to calibrate         |
|           |                |    | LSI.                                                         |
| Bit 15    | -              | -  | Reserved                                                     |
|           |                |    | CAN alternate function remapping                             |
|           |                |    | Set and cleared by software. They control the remapping      |
|           |                |    | of alternate functions CAN_RX and CAN_TX in devices          |
|           |                |    |                                                              |
|           |                |    | with a single CAN interface.                                 |
| Bit 14:13 |                |    | 00: CAN_RX is remapped on PA11, and CAN_TX is                |
| DIC 14.15 | CAN_REMAP[1:0] | rw | remapped on PA12.                                            |
|           |                |    | 01: Unused combination                                       |
|           |                |    | 10: CAN_RX is remapped on PB8, and CAN_TX is                 |
|           |                |    | remapped on PB9.                                             |
|           |                |    | 11: CAN_RX is remapped on PD0, and CAN_TX is                 |
|           |                |    | remapped on PD1.                                             |
|           |                |    | TMR4 remapping                                               |
|           |                |    | Set and cleared by software. It controls the mapping of      |
|           |                |    | TIM4 channels 1 $\sim$ 4 on the GPIO ports.                  |
|           |                |    | 0: No remapping                                              |
| Bit 12    | TMR4_REMAP     | rw | (TMR4_CH1/PB6, TMR4_CH2/PB7, TMR4_CH3/PB8,                   |
|           |                |    | TMR4_CH4/ PB9)                                               |
|           |                |    | 1: Full remapping                                            |
|           |                |    | (TMR4_CH1/PD12, TMR4_CH2/PD13, TMR4_CH3/PD14,                |
|           |                |    | TMR4_CH4/ PD15)                                              |
| L         | 1              | 1  | 1                                                            |



|           |                 |    | Note: Remapping does not affect TMR4_ETR on PE0.           |
|-----------|-----------------|----|------------------------------------------------------------|
|           |                 |    | TMR3 remapping                                             |
|           |                 |    | Set and cleared by software. It controls the mapping of    |
|           |                 |    | TIM3 channels 1 ~ 4 on the GPIO ports.                     |
|           |                 |    | 00: No remapping (CH1/PA6, CH2/PA7, CH3/PB0,               |
|           |                 |    | CH4/PB1)                                                   |
| Bit 11:10 | TMR3_REMAP[1:0] | rw | 01: Unused combination                                     |
|           |                 |    | 10: Partial remapping (CH1/PB4, CH2/PB5, CH3/PB0,          |
|           |                 |    | CH4/PB1)                                                   |
|           |                 |    | 11: Full remapping (CH1/PC6, CH2/PC7, CH3/PC8, and         |
|           |                 |    | CH4/PC9). Note: Remapping does not affect TMR3_ETR         |
|           |                 |    | on PD2.                                                    |
|           |                 |    | TMR2 remapping                                             |
|           |                 |    | Set and cleared by software. It controls the mapping of    |
|           |                 |    | TIM2 channels 1 $\sim$ 4 and external trigger (ETR) on the |
|           |                 |    | GPIO ports.                                                |
|           |                 |    | 00: No remapping (CH1/ETR/PA0, CH2/PA1, CH3/PA2,           |
| Bit 9:8   |                 |    | CH4/PA3)                                                   |
| Dit 9.0   | TMR2_REMAP[1:0] | rw | 01: Partial remapping (CH1/ETR/PA15, CH2/PB3,              |
|           |                 |    | CH3/PA2, CH4/PA3)                                          |
|           |                 |    | 10: Partial remapping (CH1/ETR/PA0, CH2/PA1,               |
|           |                 |    | CH3/PB10, CH4/PB11)                                        |
|           |                 |    | 11: Full remapping (CH1/ETR/PA15, CH2/PB3,                 |
|           |                 |    | CH3/PB10, CH4/PB11)                                        |
|           |                 |    | TMR1 remapping                                             |
|           |                 |    | Set and cleared by software. It controls the mapping of    |
|           |                 |    | TIM1 channels 1 ~ 4, 1N ~ 3N, external trigger (ETR),      |
| Bit 7:6   | TMR1_REMAP[1:0] | rw | and break input (BKIN) on the GPIO ports.                  |
|           |                 |    | 00: No remapping (ETR/PA12, CH1/PA8, CH2/PA9,              |
|           |                 |    | CH3/PA10, CH4/PA11, BKIN/PB12, CH1N/PB13,                  |
|           |                 |    | CH2N/PB14, CH3N/PB15)                                      |



|         |                   |    | 01: Partial remapping (ETR/PA12, CH1/PA8, CH2/PA9,      |
|---------|-------------------|----|---------------------------------------------------------|
|         |                   |    | CH3/PA10, CH4/PA11, BKIN/PA6, CH1N/PA7, CH2N/PB0,       |
|         |                   |    | CH3N/PB1)                                               |
|         |                   |    | 10: Unused combination                                  |
|         |                   |    | 11: Full remapping (ETR/PE7, CH1/PE9, CH2/PE11,         |
|         |                   |    | CH3/PE13, CH4/PE14, BKIN/PE15, CH1N/PE8,                |
|         |                   |    | CH2N/PE10, CH3N/PE12)                                   |
|         |                   |    | USART3 remapping                                        |
|         |                   |    | Set and cleared by software. It controls the mapping of |
|         |                   |    | USART3 CTS, RTS, CK, TX, and RX alternate function on   |
|         |                   |    | the GPIO ports.                                         |
|         |                   |    | 00: No remapping (TX/PB10, RX/PB11, CK/PB12,            |
| Bit 5:4 | USART3_REMAP[1:0] | rw | CTS/PB13, RTS/PB14)                                     |
|         |                   |    | 01: Partial remapping (TX/PC10, RX/PC11, CK/PC12,       |
|         |                   |    | CTS/PB13, RTS/PB14)                                     |
|         |                   |    | 10: Unused combination                                  |
|         |                   |    | 11: Full remapping (TX/PD8, RX/PD9, CK/PD10,            |
|         |                   |    | CTS/PD11, RTS/PD12)                                     |
|         |                   |    |                                                         |
|         |                   | rw | USART2 remapping                                        |
|         |                   |    | Set and cleared by software. It controls the mapping of |
|         |                   |    | USART2 CTS, RTS, CK, TX, and RX alternate function on   |
| Bit 3   | USART2_REMAP      |    | the GPIO ports.                                         |
|         |                   |    | 0: No remapping (CTS/PA0, RTS/PA1, TX/PA2, RX/PA3,      |
|         |                   |    | CK/PA4)                                                 |
|         |                   |    | 1: Remapping (CTS/PD3, RTS/PD4, TX/PD5, RX/PD6,         |
|         |                   |    | CK/PD7)                                                 |
|         |                   |    | USART1 remapping                                        |
|         |                   |    | Set and cleared by software. It controls the mapping of |
| Bit 2   | USART1_REMAP      | rw | USART1 TX and RX alternate function on the GPIO ports.  |
|         |                   |    | 0: No remapping (TX/PA9, RX/PA10)                       |
|         |                   |    | 1: Remapping (TX/PB6, RX/PB7)                           |
| L       | 1                 | 1  | 1                                                       |



| Bit 1 | I2C1_REMAP    | rw | I2C1 remapping<br>Set and cleared by software. It controls the mapping of<br>I2C1 SCL and SDA alternate function on the GPIO ports.<br>0: No remapping (SCL/PB6, SDA/PB7)<br>1: Remapping (SCL/PB8, SDA/PB9)                                                                                                                                                                                                                                                                                                         |
|-------|---------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 0 | SPI1_REMAP[0] | rw | <ul> <li>SPI1 remapping SPI1_REMAP[1] set in Bit 31.</li> <li>SPI1_REMAP[1:0] can be set '00', '01', or '10' by</li> <li>software to control the mapping of SPI1 NSS, SCK,</li> <li>MISO, and MOSI alternate function on the GPIO ports.</li> <li>00: No remapping (NSS/PA4, SCK/PA5, MISO/PA6,</li> <li>MOSI/PA7)</li> <li>01: Remapping (NSS/PA15, SCK/PB3, MISO/PB4,</li> <li>MOSI/PB5)</li> <li>10: Partial remapping (NSS/PA4, SCK/PA5, MISO/PG0,</li> <li>MOSI/PG1)</li> <li>11: Unused combination</li> </ul> |

## 7.5.12 Alternate External Interrupt Configuration Register 1 (AFIO\_EXTIC1)

Address offset: 0x08

| Bit       | Name                                       | Туре | Description                                                   |  |
|-----------|--------------------------------------------|------|---------------------------------------------------------------|--|
| Bit 31:16 | -                                          | -    | - Reserved                                                    |  |
|           |                                            |      | EXTINTx configuration $(x = 03)$                              |  |
|           |                                            |      | Can be read and written by software. Used to select the input |  |
|           |                                            |      | source for EXTINTx external interrupt.                        |  |
| Bit 15:0  | EXTINTx[3:0]                               | rw   | 0000: PA[x] pin                                               |  |
|           |                                            |      | 0100: PE[x] pin                                               |  |
|           |                                            |      | 0001: PB[x] pin                                               |  |
|           |                                            |      | 0101: Reserved                                                |  |
| ang       | Hangzhou Vango Technologies, Inc.174 / 782 |      |                                                               |  |

|  | 0010: PC[x] pin |
|--|-----------------|
|  | 0110: Reserved  |
|  | 0011: PD[x] pin |

## 7.5.13 Alternate External Interrupt Configuration Register 2 (AFIO\_EXTIC2)

Address offset: 0x0C

Reset value: 0x0000

| Bit       | Name         | Туре | Description                                                   |
|-----------|--------------|------|---------------------------------------------------------------|
| Bit 31:16 | -            | -    | Reserved                                                      |
| Bit 15:0  | EXTINTx[3:0] | rw   | EXTINTx configuration $(x = 47)$                              |
|           |              |      | Can be read and written by software. Used to select the input |
|           |              |      | source for EXTINTx external interrupt.                        |
|           |              |      | 0000: PA[x] pin                                               |
|           |              |      | 0001: PB[x] pin                                               |
|           |              |      | 0010: PC[x] pin                                               |
|           |              |      | 0011: PD[x] pin                                               |
|           |              |      | 0100: PE[x] pin                                               |
|           |              |      | 0101: Reserved                                                |
|           |              |      | 0110: Reserved                                                |

### 7.5.14 Alternate External Interrupt Configuration Register 3 (AFIO\_EXTIC3)

Address offset: 0x10

| Bit       | Name | Туре | Description |
|-----------|------|------|-------------|
| Bit 31:16 | -    | -    | Reserved    |



|          | EXTINTx[3:0] |    | EXTINTx configuration (x = $811$ )                            |
|----------|--------------|----|---------------------------------------------------------------|
|          |              | rw | Can be read and written by software. Used to select the input |
|          |              |    | source for EXTINTx external interrupt.                        |
|          |              |    | 0000: PA[x] pin                                               |
| Bit 15:0 |              |    | 0001: PB[x] pin                                               |
| DIC 13.0 |              |    | 0010: PC[x] pin                                               |
|          |              |    | 0011: PD[x] pin                                               |
|          |              |    | 0100: PE[x] pin                                               |
|          |              |    | 0101: Reserved                                                |
|          |              |    | 0110: Reserved                                                |

## 7.5.15 Alternate External Interrupt Configuration Register 4 (AFIO\_EXTIC4)

Address offset: 0x14

Reset value: 0x0000

| Bit 31:16 | -            | -  | Reserved                                                      |
|-----------|--------------|----|---------------------------------------------------------------|
| Bit 15:0  | EXTINTx[3:0] | rw | EXTINTx configuration ( $x = 1215$ )                          |
|           |              |    | Can be read and written by software. Used to select the input |
|           |              |    | source for EXTINTx external interrupt.                        |
|           |              |    | 0000: PA[x] pin                                               |
|           |              |    | 0001: PB[x] pin                                               |
|           |              |    | 0010: PC[x] pin                                               |
|           |              |    | 0011: PD[x] pin                                               |
|           |              |    | 0100: PE[x] pin                                               |
|           |              |    | 0101: Reserved                                                |
|           |              |    | 0110: Reserved                                                |

# 7.5.16 AF Remap and Debug I/O Configuration Register 2 (AFIO\_MAP2)

| Bit       | Name           | Туре | Description                                                                                                                                                                                                                                                                            |
|-----------|----------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:22 | -              | -    | Reserved                                                                                                                                                                                                                                                                               |
| Bit 21    | EXT_SPIF_EN    | rw   | External SPI Flash Interface enable<br>Set and cleared by software. It controls whether to use<br>external SPI Flash.                                                                                                                                                                  |
| Bit 20:19 | -              | -    | Reserved                                                                                                                                                                                                                                                                               |
| Bit 18    | I2C3_REMAP     | rw   | I2C3 internal remap<br>Set and cleared by software. It controls I2C3 internal<br>remapping. Please refer to 7.4.7.                                                                                                                                                                     |
| Bit 17    | SPI4_REMAP     | rw   | SPI4 internal remap<br>Set and cleared by software. It controls SPI4 internal<br>remapping. Please refer to 7.4.8.                                                                                                                                                                     |
| Bit 16:11 | -              | -    | Reserved                                                                                                                                                                                                                                                                               |
| Bit 10    | XMC_NADV_REMAP | rw   | <ul> <li>XMCNADV connect</li> <li>Set and cleared by software. It controls whether to use</li> <li>XMC_NADV signal.</li> <li>0: XMC_NADV is connected to pin. (By default)</li> <li>1: XMC_NADV is unused, and the corresponding pin can be used by other peripherals.</li> </ul>      |
| Bit 9:6   |                | -    | Reserved                                                                                                                                                                                                                                                                               |
| Bit 5     | TMR9_REMAP rw  |      | TMR9 channel1/2 internal remap<br>Set and cleared by software. It controls TMR9 channel1/2<br>internal remapping.<br>When it is cleared, TMR9_CH1 is connected to PA2,<br>TMR9_CH2 is connected to PA3. When it is set, TMR9_CH1 is<br>connected to PE5, TMR9_CH2 is connected to PE6. |
| Bit 4:0   |                | _    | Reserved                                                                                                                                                                                                                                                                               |



# 7.5.17 AF Remap and Debug I/O Configuration Register 3 (AFIO\_MAP3)

Address offset: 0x20

Reset value: 0x0000000

| Bit      | Name      | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|-----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:4 | -         | -    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 3:0  | TMR9_GRMP | rw   | TMR9 remapping<br>TMR9_GRMP[0] does not have physical register, and it directly<br>maps to AFIO_MAP2 Bit 5 (TMR9_REMAP); writing or reading<br>this bit means to write/read AFIO_MAP2 Bit 5<br>(TMR9_REMAP).<br>Set and cleared by software. It controls alternate function<br>TMR9_CH1 and TMR9_CH2 remapping.<br>0000: TMR9_CH1 connects to PA2; TMR9_CH2 connects to<br>PA3.<br>0001: TMR9_CH1 connects to PE5; TMR9_CH2 connects to<br>PE6.<br>0010 ~ 1111: Reserved for future extension. Please do not<br>use. |

# 7.5.18 AF Remap and Debug I/O Configuration Register 4 (AFIO\_MAP4)

Address offset: 0x24

| Bit       | Name         | Туре | ype Description                                    |  |
|-----------|--------------|------|----------------------------------------------------|--|
| Bit 31:20 | -            | -    | Reserved for future extension, please all write 0. |  |
| Bit 19    | TMR5CH4_IRMP | rw   | TMR5 channel4 internal remap                       |  |



| -         |                    | 1  |                                                              |
|-----------|--------------------|----|--------------------------------------------------------------|
|           |                    |    | Set and cleared by software. It controls TMR5 channel 4      |
|           |                    |    | internal remapping. When this bit is cleared, TMR5_CH4 is    |
|           |                    |    | connected to PA3; when it is set, LSI internal oscillator is |
|           |                    |    | connected to TMR5_CH4 for calibration to LSI.                |
| Bit 18:16 | -                  | -  | Reserved                                                     |
|           |                    |    | TMR4 remapping                                               |
| Bit 15:12 |                    |    | Set and cleared by software. It controls TMR4 internal       |
| DIL 15:12 | TMR4_GRMP          | rw | remapping. Please refer to 7.4.5.                            |
|           |                    |    | 0000 $\sim$ 1111: If not used, please all write 0.           |
|           | Bit 11:8 TMR3_GRMP | rw | TMR3 remapping                                               |
|           |                    |    | Set and cleared by software. It controls TMR3 internal       |
| Bit 11:8  |                    |    | remapping. Please refer to 7.4.5.                            |
|           |                    |    | 0000 $\sim$ 1111: If not used, please all write 0.           |
| Bit 7     | -                  | -  | Reserved                                                     |
|           |                    |    | TMR2 remapping                                               |
|           | TMR2_GRMP          | rw | Set and cleared by software. It controls TMR2 internal       |
| Bit 6:4   |                    |    | remapping. Please refer to 7.4.5.                            |
|           |                    |    | 0000 $\sim$ 1111: If not used, please all write 0.           |
|           |                    |    | TMR1 remapping                                               |
|           | TMR1_GRMP          | rw | Set and cleared by software. It controls TMR1 internal       |
| Bit 3:0   |                    |    | remapping. Please refer to 7.4.5.                            |
|           |                    |    | $0000 \sim 1111$ : If not used, please all write 0.          |
|           |                    |    |                                                              |

# 7.5.19 AF Remap and Debug I/O Configuration Register 5 (AFIO\_MAP5)

Address offset: 0x28

| Bit       | Name      | Туре   | Description                 |           |
|-----------|-----------|--------|-----------------------------|-----------|
| Bit 31:28 | SPI4_GRMP | rw     | SPI4 internal remap         |           |
| Jango     |           | Hangzh | ou Vango Technologies, Inc. | 179 / 782 |

| 1         |             |    |                                                                                                                                                                                                                                                           |  |
|-----------|-------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|           |             |    | Set and cleared by software. It controls SPI4 internal                                                                                                                                                                                                    |  |
|           |             |    | remapping. Please refer to 7.4.8.                                                                                                                                                                                                                         |  |
|           |             |    | 0000 ~ 1111: If not used, please all write 0.                                                                                                                                                                                                             |  |
| 27: 24    | SPI3_GRMP   | rw | <ul> <li>SPI3 internal remap</li> <li>Set and cleared by software. It controls SPI3 internal</li> <li>remapping. Please refer to 7.4.8.</li> <li>0000 ~ 1111: If not used, please all write 0.</li> </ul>                                                 |  |
| Bit 23:20 | SPI2_GRMP   | rw | <ul> <li>SPI2 internal remap</li> <li>Set and cleared by software. It controls SPI2 internal</li> <li>remapping. Please refer to 7.4.8.</li> <li>0000 ~ 1111: If not used, please all write 0.</li> </ul>                                                 |  |
| Bit 19:16 | SPI1_GRMP   | rw | <ul> <li>SPI1 remapping</li> <li>Set and cleared by software. It controls SPI1 internal</li> <li>remapping. Please refer to 7.4.8.</li> <li>0000 ~ 1111: If not used, please all write 0.</li> </ul>                                                      |  |
| Bit 15:12 | I2C3_GRMP   | rw | I2C3 internal remap<br>Set and cleared by software. It controls I2C3 internal<br>remapping.<br>0000 ~ 0011: Please refer to 7.4.8.<br>0100 ~ 1111: Reserved for future extension. Please do not<br>use.                                                   |  |
| Bit 11:8  | -           | _  | Reserved for future extension, please all write 0.                                                                                                                                                                                                        |  |
| Bit 7:4   | I2C1_GRMP   | rw | I2C1 remapping         Set and cleared by software. It controls GPIO remapping of         I2C1 SCL and SDA alternate function.         0000 ~ 0011: Please refer to 7.4.7.         0100 ~ 1111: Reserved for future extension. Please do not         use. |  |
| Bit 3:0   | USART5_GRMP | rw | USART5 remapping<br>Set and cleared by software. It controls USART5 internal<br>remapping. Please refer to 7.4.6.                                                                                                                                         |  |

# 7.5.20 AF Remap and Debug I/O Configuration Register 6 (AFIO\_MAP6)

Address offset: 0x2C

Reset value: 0x0000000

| Bit       | Name        | Туре | Description                                                                                                                                                                                  |
|-----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:28 | UART4_GRMP  | rw   | UART4 remapping<br>Set and cleared by software. It controls alternate function<br>UART4_RX and UART_TX remapping.<br>Please refer to 7.4.6.<br>0000 ~ 1111: If not used, please all write 0. |
| Bit 27:24 | USART3_GRMP | rw   | USART3 remapping<br>Set and cleared by software. It controls USART3 internal<br>remapping. Please refer to 7.4.6.<br>0000 ~ 1111: If not used, please all write 0.                           |
| Bit 23:20 | USART2_GRMP | rw   | USART2 remapping<br>Set and cleared by software. It controls USART2 internal<br>remapping. Please refer to 7.4.6.<br>0000 ~ 1111: If not used, please all write 0.                           |
| Bit 19:16 | USART1_GRMP | rw   | USART1 remapping<br>Set and cleared by software. It controls USART1 internal<br>remapping. Please refer to 7.4.6.<br>0000 ~ 1111: If not used, please all write 0.                           |
| Bit 15:4  | -           | -    | Reserved                                                                                                                                                                                     |
| Bit 3:0   | CAN1_GRMP   | rw   | CAN1 remapping<br>Set and cleared by software. It controls CAN1 internal<br>remapping. Please refer to 7.4.2.<br>0000 ~ 1111: If not used, please all write 0.                               |



# 7.5.21 AF Remap and Debug I/O Configuration Register 7 (AFIO\_MAP7)

Address offset: 0x30

Reset value: 0x0000000

| Bit       | Name          | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|-----------|---------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 31:28 | -             | -    | Reserved for future extension, please all write 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| Bit 27    | XMC_NADV_GRMP | rw   | XMCNADV remapping<br>Set and cleared by software. It controls whether XMC_NADV<br>signal is used. 0: XMC_NADV is connected to pins. (By<br>default)<br>1: XMC_NADV is not used. The corresponding pins can be<br>used by other peripherals.                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| Bit 26:24 | XMC_GRMP      | rw   | XMC remapping<br>Set and cleared by software. It controls XMC internal<br>remapping. Please refer to 7.4.9.<br>000 ~ 111: If not used, please all write 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| Bit 23:19 | -             | -    | Reserved for future extension, please all write 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| Bit 18:16 | SWJTAG_GRMP   | rw   | Serial wire JTAG remapping<br>These bits can only be written by software. (Reading these bits<br>returns undefined values.) It configures SWJ and tracks<br>alternate function I/O port. SWJ (serial wire JTAG) supports<br>JTAG or SWD to access Cortex debug port. Default state after<br>system rest is to enable SWJ without tracking function; in this<br>state JATG or SYSCLKSEL (serial wire) mode can be selected<br>through certain signal on the JTMS/JTCKpins.<br>000: Full SWJ (JTAG – DP + SW - DP): Reset state<br>001: Full SWJ (JTAG – DP + SW - DP) but no NJTRST.<br>010: JTAG-DP is disabled; SW-DP is enabled.<br>100: JTAG-DP is disabled; SW-DP is disabled. |  |



|           |               |    | Other combination: No effect                                                                                                                                                                                                                                                                                                                                                    |
|-----------|---------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:10 |               | -  | Reserved for future extension, please all write 0.                                                                                                                                                                                                                                                                                                                              |
| Bit 9     |               | -  | Reserved                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 8     |               | -  | Reserved                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 7:6   |               | -  | Reserved for future extension, please all write 0.                                                                                                                                                                                                                                                                                                                              |
| Bit 5     | ADC1_ETR_GRMP | rw | <ul> <li>ADC1 external trigger regular conversion remapping</li> <li>Set and cleared by software. It controls ADC1 external trigger</li> <li>regular conversion remapping.</li> <li>0: ADC1 external trigger regular conversion is connected to</li> <li>EXTINT11.</li> <li>1: ADC1 external trigger regular conversion is connected to</li> <li>TMR8_TRGO.</li> </ul>          |
| Bit 4     | ADC1_ETI_GRMP | rw | <ul> <li>ADC1 external trigger injected conversion remapping</li> <li>Set and cleared by software. It controls ADC1 External trigger</li> <li>injected conversion remapping.</li> <li>0: ADC1 external trigger injected conversion is connected to</li> <li>EXTINT15.</li> <li>1: ADC1 external trigger injected conversion is connected to</li> <li>TMR8 channel 4.</li> </ul> |
| Bit 3     | EXT_SPIF_GEN  | rw | External SPI Flash interface enable<br>Set and cleared by software. It controls whether external SPI<br>Flash is used. Its relation with EXT_SPIF_EN is full mapping.                                                                                                                                                                                                           |
| Bit 2:0   | -             | -  | Reserved                                                                                                                                                                                                                                                                                                                                                                        |

# 7.5.22 AF Remap and Debug I/O Configuration Register 8 (AFIO\_MAP8)

Address offset: 0x34

Reset value: 0x0000000



| Bit           | Name        | Туре | Description                                                                                                                                                        |
|---------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:28     | UART8_GRMP  | rw   | UART8remapping<br>Set and cleared by software. It controls UART8 internal<br>remapping. Please refer to 7.4.6.<br>0000 ~ 1111: If not used, please all write 0.    |
| Bit 27:<br>24 | UART7_GRMP  | rw   | UART7 remapping<br>Set and cleared by software. It controls UART7 internal<br>remapping. Please refer to 7.4.6.<br>0000 ~ 1111: If not used, please all write 0.   |
| Bit 23:<br>20 | USART6_GRMP | rw   | USART6 remapping<br>Set and cleared by software. It controls USART6 internal<br>remapping. Please refer to 7.4.6.<br>0000 ~ 1111: If not used, please all write 0. |
| Bit 19:16     | -           | -    | Reserved                                                                                                                                                           |
| Bit 15:0      | -           | -    | Reserved for future extension, please all write 0.                                                                                                                 |



## **8 Interrupts and Events**

## 8.1 Nested Vectored Interrupt Controller

#### 8.1.1 Features

- 79 maskable interrupt channels (not including 16 Cortex<sup>®</sup>-M4F interrupt lines);
- 16 programmable priority levels (4-bit interrupt priority configuration);
- Low-latency processing of exceptions and interrupts;
- Power management control;
- Implementation of system control register;

Nested vectored interrupt controller (NVIC) is closely connected to the processor core interface, which enables low-latency interrupt processing and highly efficient late-arriving interrupt processing.

Nested vectored interrupt controller also manages interrupts such as core exception.

## 8.1.2 System Tick (SysTick) Calibration Value Register

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.

## 8.1.3 Interrupt and Exception Vectors

Table 8-1 lists the vector table of V84XXX series.

| Position | Priority | Priority<br>Type | Name   | Description            | Address     |
|----------|----------|------------------|--------|------------------------|-------------|
|          | -        | -                | -      | Reserved               | 0x0000_0000 |
|          | -3       | Fixed            | Reset  | Reset                  | 0x0000_0004 |
|          | -2       | Fixed            | NMI    | Non maskable interrupt | 0x0000_0008 |
|          | 2        | r ixeu           | TAL IT | The RCC Clock Security | 0,0000_0000 |

Table 8-1 Vector Table of V84XXX Series



|   |    | 1            |              |                                            |                             |
|---|----|--------------|--------------|--------------------------------------------|-----------------------------|
|   |    |              |              | System (CFD) is linked to the              |                             |
|   |    |              |              | NMI vector.                                |                             |
|   | -1 | Fixed        | HardFault    | All class of fault                         | 0x0000_000C                 |
|   | 0  | Configurable | MemoryManage | Memory management                          | 0x0000_0010                 |
|   | 1  | Configurable | BusFault     | Pre-fetch fault, memory<br>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<br>instruction | 0x0000_002C                 |
|   | 4  | Configurable | DebugMonitor | Debug Monitor                              | 0x0000_0030                 |
|   | -  | -            | -            | Reserved                                   | 0x0000_0034                 |
|   | 5  | Configurable | PendSV       | Pendable request for system service        | 0x0000_0038                 |
|   | 6  | Configurable | Systick      | System tick timer                          | 0x0000_003C                 |
| 0 | 7  | Configurable | WWDG         | Window Watchdog interrupt                  | 0x0000_0040                 |
| 1 | 8  | Configurable | PVD          | PVD from EXTI interrupt                    | 0x0000_0044                 |
| 2 | 9  | Configurable | TAMPER       | Tamper interrupt                           | 0x0000_0048                 |
| 3 | 10 | Configurable | RTC          | RTC global inte rrupt                      | 0x0000_004C                 |
| 4 | 11 | Configurable | FLASH        | Flash global interrupt                     | 0x0000_0050                 |
| 5 | 12 | Configurable | RCC          | Reset and RCC interrupt                    | 0x0000_0054                 |
| 6 | 13 | Configurable | EXTINT0      | EXTI Line0 interrupt                       | 0x0000_0058                 |
| 7 | 14 | Configurable | EXTINT1      | EXTI Line1 interrupt                       | 0x0000_005C                 |
| 8 | 15 | Configurable | EXTINT2      | EXTI Line2 interrupt                       | 0x0000_0060                 |
| 9 | 16 | Configurable | EXTINT3      | EXTI Line3 interrupt                       | 0x0000_0064                 |



| 10          | 17                                          | Configurable | EXTINT4         | EXTI Line4 interrupt                                   | 0x0000_0068 |  |  |
|-------------|---------------------------------------------|--------------|-----------------|--------------------------------------------------------|-------------|--|--|
| 11          | 18                                          | Configurable | DMA1 channel1   | DMA1 channel1 global<br>interrupt                      | 0x0000_006C |  |  |
| 12          | 19                                          | Configurable | DMA1 channel2   | DMA1 channel2 global<br>interrupt                      | 0x0000_0070 |  |  |
| 13          | 20                                          | Configurable | DMA1 channel3   | DMA1 channel3 global<br>interrupt                      | 0x0000_0074 |  |  |
| 14          | 21                                          | Configurable | DMA1 channel4   | DMA1 channel4 global<br>interrupt                      | 0x0000_0078 |  |  |
| 15          | 22                                          | Configurable | DMA1 channel5   | DMA1 channel5 global<br>interrupt                      | 0x0000_007C |  |  |
| 16          | 23                                          | Configurable | DMA1 channel6   | DMA1 channel6 global<br>interrupt                      | 0x0000_0080 |  |  |
| 17          | 24                                          | Configurable | DMA1 channel7   | DMA1 channel7 global<br>interrupt                      | 0x0000_0084 |  |  |
| 18          | 25                                          | Configurable | ADC1            | ADC1 global interrupt                                  | 0x0000_0088 |  |  |
| 19          | 26                                          | Configurable | USB_HP_CAN1_TX  | USB high priority or CAN1 TX<br>interrupt              | 0x0000_008C |  |  |
| 20          | 27                                          | Configurable | USB_LP_CAN1_RX0 | USB low priority or CAN1 RX0<br>interrupt              | 0x0000_0090 |  |  |
| 21          | 28                                          | Configurable | CAN_RX1         | CAN1 RX1 interrupt                                     | 0x0000_0094 |  |  |
| 22          | 29                                          | Configurable | CAN_SCE         | CAN SCE interrupt                                      | 0x0000_0098 |  |  |
| 23          | 30                                          | Configurable | EXTINT9_5       | EXTI Line[9:5] interrupt                               | 0x0000_009C |  |  |
| 24          | 31                                          | Configurable | TMR1_BRK_TMR9   | TMR1 break interrupt and<br>TMR9 global interrupt      | 0x0000_00A0 |  |  |
| 25          | 32                                          | Configurable | TMR1_OV_TMR10   | TMR1 update interrupt and<br>TMR10<br>global interrupt | 0x0000_00A4 |  |  |
| 26          | 33                                          | Configurable | TMR1_TRG_COM_TM | TMR1 trigger and                                       | 0x0000_00A8 |  |  |
| <b>V</b> al | Hangzhou Vango Technologies, Inc. 187 / 782 |              |                 |                                                        |             |  |  |

|    |    |              | R11             | communication interrupt and |             |
|----|----|--------------|-----------------|-----------------------------|-------------|
|    |    |              |                 | TMR11 global interrupt      |             |
| 27 | 34 | Configurable | TMR1_CC         | TMR1 capture compare        | 0x0000_00AC |
|    | 51 | Configurable |                 | interrupt                   |             |
| 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_EV         | I2C1 event interrupt        | 0x0000_00BC |
| 32 | 39 | Configurable | I2C1_ER         | I2C1 error interrupt        | 0x0000_00C0 |
| 33 | 40 | Configurable | I2C2_EV         | I2C2 event interrupt        | 0x0000_00C4 |
| 34 | 41 | Configurable | I2C2_ER         | I2C2 error interrupt        | 0x0000_00C8 |
| 35 | 42 | Configurable | SPI1            | SPI1 global interrupt       | 0x0000_00CC |
|    | 12 |              |                 | SPI2 and I2S2EXT global     | 0.0000.0000 |
| 36 | 43 | Configurable | SPI2_I2S2EXT    | 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 | EXTINT15_10     | EXTI Line[15:10] interrupt  | 0x0000_00E0 |
| 41 | 48 | Configurable | RTCAlarm        | RTC alarm through EXTI line | 0x0000_00E4 |
|    |    |              |                 | interrupt                   |             |
| 42 | 49 | Configurable | USBWakeUp       | USB Wakeup through EXTI     | 0x0000_00E8 |
|    |    |              |                 | line interrupt              |             |
| 43 | 50 | Configurable | TMR8_BRK_TMR12  | TMR8 Break interrupt and    | 0x0000_00EC |
|    |    |              |                 | TMR12 global interrupt      |             |
| 44 | 51 | Configurable | TMR8_OV_TMR13   | TMR8 update interrupt and   | 0x0000_00F0 |
|    |    |              |                 | TMR13 global interrupt      |             |
| 45 | 52 | Configurable | TMR8_TRG_COM_TM | TMR8 trigger and            | 0x0000_00F4 |
|    |    |              | R14             | communication interrupt and |             |



|    |    |              |                 | VO4AAA TECIIIII                                     | car i randar |
|----|----|--------------|-----------------|-----------------------------------------------------|--------------|
|    |    |              |                 | TMR14 global interrupt                              |              |
| 46 | 53 | Configurable | TMR8_CC         | TMR8 capture compare<br>interrupt                   | 0x0000_00F8  |
| 47 | 54 | Configurable | -               | Reserved                                            | 0x0000_00FC  |
| 48 | 55 | Configurable | ХМС             | XMC global interrupt                                | 0x0000_0100  |
| 49 | 56 | Configurable |                 | 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            | TMR6 global interrupt                               | 0x0000_0118  |
| 55 | 62 | Configurable | TMR7            | TMR7 global interrupt                               | 0x0000_011C  |
| 56 | 63 | Configurable | DMA2 channel1   | DMA2 channel1 global<br>interrupt                   | 0x0000_0120  |
| 57 | 64 | Configurable | DMA2 channel2   | DMA2 channel2 global<br>interrupt                   | 0x0000_0124  |
| 58 | 65 | Configurable | DMA2 channel3   | DMA2 channel3 global<br>interrupt                   | 0x0000_0128  |
| 59 | 66 | Configurable | DMA2 channel4_5 | DMA2 channel4 and DMA2<br>channel5 global interrupt | 0x0000_012C  |
| 60 | 67 | Configurable | 2               | 2 global interrupt                                  | 0x0000_0130  |
| 61 | 68 | Configurable | I2C3_EV         | I2C3 event interrupt                                | 0x0000_0134  |
| 62 | 69 | Configurable | I2C3_ER         | I2C3 error interrupt                                | 0x0000_0138  |
| 63 | 70 | Configurable | SPI4            | SPI4 global interrupt                               | 0x0000_013C  |
| 64 | 71 | -            | -               | Reserved                                            | 0x0000_0140  |
| 65 | 72 | -            | -               | Reserved                                            | 0x0000_0144  |

| 66 | 73 | -            | -                   | Reserved                | 0x0000_0148 |
|----|----|--------------|---------------------|-------------------------|-------------|
| 67 | 74 | -            | -                   | Reserved                | 0x0000_014C |
| 68 | 75 | Configurable | -                   | Reserved                | 0x0000_0150 |
| 69 | 76 | Configurable | -                   | Reserved                | 0x0000_0154 |
| 70 | 77 | Configurable | -                   | Reserved                | 0x0000_0158 |
| 71 | 78 | Configurable | -                   | Reserved                | 0x0000_015C |
| 72 | 79 | Configurable | -                   | Reserved                | 0x0000_0160 |
| 73 | 80 | Configurable | USB_HP <sup>1</sup> | USB high priority       | 0x0000_0164 |
| 74 | 81 | Configurable | USB_LP <sup>1</sup> | USB low priority        | 0x0000_0168 |
| 75 | 82 | Configurable | DMA2 Channel 6_7    | DMA2 channel 6 and DMA2 | 0x0000_016C |
|    |    |              |                     | channel 7               |             |
|    |    |              |                     | global interrupt        |             |
| 76 | 83 | Configurable | USART6              | UART6 global interrupt  | 0x0000_0170 |
| 77 | 84 | Configurable | UART7               | UART7 global interrupt  | 0x0000_0174 |
| 78 | 85 | Configurable | UART8               | UART8 global interrupt  | 0x0000_0178 |

*Note:* 1.USBDEV module interrupt supports remapping, which is controlled by RCC\_INTCTRL, USB\_INT\_CTRL bit; when USB\_INT\_CTRL = 0, USB\_HP uses interrupt 19, and USB\_LP uses interrupt 20; when USB\_INT\_CTRL = 1, USB\_HP uses interrupt 73, and USB\_LP uses interrupt 74.

## 8.2 External Interrupt/Event Controller (EXTI)

The external interrupt/event controller consists of 19 edge detectors which generate event/interrupt requests. Each input line can be independently configured to select input type (event or interrupt) and the corresponding trigger event (rising edge, falling edge, or both edges). Each input line can be masked independently. Pending register maintains the interrupt requests of status line.

#### 8.2.1 Main Features

The main features of EXTI controller are as follows:

• Independent trigger and mask on each interrupt/event



- Dedicated status bit for each interrupt line
- Up to 19 software event/interrupt requests
- Detection of external signal with pulse width lower than APB2 clock period. Please refer to the

electrical characteristics section of the data sheet for the detailed information on this parameter.

#### 8.2.2 Block Diagram

Figure 8-1 External Interrupt/Event Controller Block Diagram



#### 8.2.3 Wakeup Event Management

V84XXX can wake up the core (WFE) by managing external or internal events. Wakeup events can be generated by the following configuration:

• Enabling an interrupt in the peripheral control register but not in NVIC, and enabling the SEVONPEND bit in the Cortex<sup>®</sup>-M4F system control register. When CPU resumes from WFE, the corresponding peripheral interrupt pending bit and the peripheral NVIC IRQ channel pending bit (in the NVIC interrupt clear pending register) should be cleared.

• Configure an external or internal EXTI line as event mode. When CPU resumes from WFE, it is not necessary to clear the corresponding peripheral interrupt pending bit or the NVIC IRQ channel pending bit since the pending bit corresponding to the event line is not set.

In V84XXX devices, Ethernet wakeup events also have the WFE wakeup capability. To use an external



I/O port as a wakeup event, please refer to Section 8.2.4.

#### 8.2.4 Function Overview

To generate interrupts, the interrupt line should be configured and enabled first. This is done by programming the two trigger registers with the desired edge detection and enabling the interrupt request by writing '1' to the corresponding bit in the interrupt mask register. When the selected edge occurs on the external interrupt line, an interrupt request is generated. The pending bit corresponding to the interrupt line is also set. This request is reset by writing '1' to the corresponding bit in pending register.

To generate events, the event line should be configured and enabled first. This is done by programming the two trigger registers with the desired edge detection and enabling the event request by writing '1' to the corresponding bit in the event mask register. When the selected edge occurs on the event line, an event request pulse is generated. The pending bit corresponding to the event line is not set.

An interrupt/event request can also be generated by software when writing '1' to the software interrupt/event register.

#### Hardware interrupt selection

To configure the 19 lines as interrupt sources, use the following procedure:

- Configure the mask bits of the 19 interrupt lines (EXTI\_INTEN)
- Configure the trigger selection bits of the selected interrupt lines (EXTI\_RTRSEL and EXTI\_FTRSEL)
- Configure the enable and mask bits corresponding to the NVIC IRQ channel of external interrupt controller (EXTI), so that interrupts from the 19 lines can be correctly served.

#### Hardware event selection

To configure the 19 lines as event sources, use the following procedure:

- Configure the mask bits of the 19 event lines (EXTI\_EVTEN)
- Configure the trigger selection bits of the event lines (EXTI\_RTRSEL and EXTI\_FTRSEL)

#### Software interrupt/event selection

The 19 lines can be configured as software interrupt/ event lines. The following is the procedure to generate a software interrupt:

• Configure the mask bits of the 19 interrupt/ event lines (EXTI\_INTEN, EXTI\_EVTEN)

• Set the request bit in the software interrupt register (EXTI\_SWIE)

Hangzhou Vango Technologies, Inc.

#### 8.2.5 External Interrupt/Event Line Mapping

The 80 GPIOs are connected to the 16 external interrupt/event lines in the following manners shown in

Figure 8-2:





To configure the external interrupt/event on GPIO lines with AFIO\_EXTICx, the AFIO clock should first be enabled. Please refer to Section 3.3.7.

The other three EXTI lines are connected as follows:

**EXTI** line 16 is connected to the PVD output.



- EXTI line 17 is connected to the RTC alarm event.
- EXTI line 18 is connected to the USB wakeup event.

### 8.3 EXTI Registers Description

#### 8.3.1 Interrupt Mask Register (EXTI\_INTEN)

Address offset: 0x00

Reset value: 0x0000 0000

| Bit       | Name | Туре | Description                                     |
|-----------|------|------|-------------------------------------------------|
| Bit 31:19 | -    | -    | Reserved. Must be kept at reset value '0'.      |
|           |      |      | Interrupt Mask on line x                        |
| Bit 18:0  | MRx  | rw   | 0: Interrupt request from Line x is masked.     |
|           |      |      | 1: Interrupt request from Line x is not masked. |

### 8.3.2 Event Mask Register (EXTI\_EVTEN)

Address offset: 0x04

Reset value: 0x0000 0000

| Bit       | Name | Туре | Description                                 |
|-----------|------|------|---------------------------------------------|
| Bit 31:19 | -    | -    | Reserved. Must be kept at reset value '0'.  |
|           |      |      | Event Mask on line x                        |
| Bit 18:0  | MRx  | rw   | 0: Event request from Line x is masked.     |
|           |      |      | 1: Event request from Line x is not masked. |

# 8.3.3 Rising Edge Trigger Selection Register (EXTI\_RTRSEL)

Address offset: 0x08



| Bit Name Type |     | Туре                                             | Description                                                            |
|---------------|-----|--------------------------------------------------|------------------------------------------------------------------------|
| Bit 31:19     | -   | -                                                | Reserved. Must be kept at reset value '0'.                             |
|               |     | Rising trigger event configuration bit of line x |                                                                        |
| Bit 18:0      | TRx | rw                                               | 0: Rising trigger (event and interrupt) on input line $x$ is disabled. |
|               |     |                                                  | 1: Rising trigger (event and interrupt) on input line $x$ is enabled.  |

Note: The external wakeup lines are edge triggered, and no glitches are generated on these lines. When the EXTI\_RTRSEL register is written, rising edge signal on external interrupt line cannot be identified, and the pending bit will not be set, either. Rising and falling edge triggers can be set at the same time for the same interrupt line. In this configuration, both edges can trigger interrupts.

# 8.3.4 Falling Edge Trigger Selection Register (EXTI\_FTRSEL)

Address offset: 0x0C

Reset value: 0x0000 0000

| Bit       | Name | Туре | Description                                                                                                                                                                                                                    |
|-----------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:19 | -    | -    | Reserved. Must be kept at reset value '0'.                                                                                                                                                                                     |
| Bit 18:0  | TRx  | rw   | <ul><li>Falling trigger event configuration bit of line x</li><li>0: Falling trigger (event and interrupt) on input line x is disabled.</li><li>1: Falling trigger (event and interrupt) on input line x is enabled.</li></ul> |

Note: The external wakeup lines are edge triggered, and no glitches are generated on these lines. When the EXTI\_RTRSEL register is written, falling edge signal on external interrupt line cannot be identified, and the pending bit will not be set, either. Rising and falling edge triggers can be set at the same time for the same interrupt line. In this configuration, both edges can trigger interrupts.

#### 8.3.5 Software Interrupt Event Register (EXTI\_SWIE)

Address offset: 0x10



| Bit Name Type |        | Туре  | Description                                                              |  |
|---------------|--------|-------|--------------------------------------------------------------------------|--|
| Bit 31:19     | -      | -     | Reserved. Must be kept at reset value '0'.                               |  |
|               |        |       | Software interrupt on line x                                             |  |
|               | SWIERx | ₹x rw | If the interrupt is enabled on this line in the EXTI_INTEN, writing a    |  |
| Bit 18:0      |        |       | '1' to this bit when it is set to '0' sets the corresponding pending bit |  |
| Dit 10.0      |        |       | in EXTI_PND resulting in an interrupt request generation.                |  |
|               |        |       | Note: This bit is cleared by clearing the corresponding bit in the       |  |
|               |        |       | EXTI_PND register (by writing a '1' to the bit).                         |  |

## 8.3.6 Pending Register (EXTI\_PND)

Address offset: 0x14

| Bit       | Name | Туре | Description                                                                                                                                                                                                           |
|-----------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:19 | -    | -    | Reserved. Must be kept at reset value '0'.                                                                                                                                                                            |
| Bit 18:0  | PRx  | rw   | Pending bit<br>0: No trigger request occurred.<br>1: Selected trigger request occurred.<br>This bit is set when the selected edge event occurs on the external<br>interrupt line. This bit is cleared by writing `1'. |



# **9 DMA Controller (DMA)**

## 9.1 DMA Introduction

Direct memory access (DMA) provides high-speed data transfer between peripheral and memory, or between memory and memory. Without the intervention of CPU, data can be quickly transferred through DMA, keeping CPU resources free for other operations.

There are 14 channels in the two DMA controllers (7 in DMA1, 7 in DMA2). Each channel specifically manages memory access requests from one or more peripherals. There is one arbiter for coordinating the priority of each DMA request.

## 9.2 DMA Main Features

• 14 independently configurable channels (requests): 7 for DMA1 and 7 for DMA2

• Each of the 14 channels is connected to the dedicated hardware DMA requests and supports software trigger. This configuration is done by software.

• On the same DMA block, priorities between several requests are software programmable (4 levels including very high, high, medium, and low). In case of equality, priority is given by hardware (request 0 has priority over request 1, and so on).

• Independent source and destination transfer size (byte, half-word, and word), simulation of packing and unpacking. Source/ Destination addresses must be aligned according to the data size.

• Support circular buffer management

• 3 event flags on each channel (DMA half transfer, DMA transfer complete, and DMA transfer error). The 3 events are logically ORed together in a single interrupt request.

- Memory-to-memory transfer
- Peripheral-to-memory, memory-to-peripheral, and peripheral-to-peripheral transfers

• Flash, peripheral SRAM, APB1, APB2, and AHB peripherals can be accessed as source and destination.

• Programmable amount of data to be transferred: Up to 65535

Figure 9-1 shows the function block diagram:

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

DMA Controller and Cortex<sup>®</sup>-M4F core share the same system data bus, executing direct memory data transfer. When CPU and DMA access the same destination (RAM or peripherals), DMA request will stop CPU access to system bus for several cycles. The bus arbiter implements round-robin scheduling to ensure at least half of the system bus bandwidth (memory or peripheral) for CPU.

#### 9.3.1 DMA Transaction

After an event, the peripheral asserts a request signal to the DMA controller, which serves the request according to the channel priorities. Afterwards, the DMA controller accesses the peripheral, and asserts 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 deasserts the acknowledge signal. If there



are more requests, the peripheral can initiate the next transaction.

To sum up, each DMA transfer involves the following procedure:

• Load data from the memory address programmed by peripheral data register or by current peripheral/memory address register. The start address used for the first transfer is the peripheral base address or memory unit programmed in the DMA\_CPBAx or DMA\_CMBAx register.

• Store the data loaded to the memory address programmed by peripheral data register or current peripheral/memory address register. The start address used for the first transfer is the peripheral base address or memory unit programmed in the DMA\_CPBAx or DMA\_CMBAx register.

• Execute a decrementing operation of the DMA\_TCNTx register, which contains the number of unfinished transactions.

#### 9.3.2 Arbiter

The arbiter manages the channel requests based on their priorities to enable peripheral/memory access. There are two stages in priority management:

• Software: The priority of each channel can be configured in the DMA\_CHCTRLx register. There are four levels:

- Very high priority
- High priority
- Medium priority
- Low priority

• Hardware: If 2 requests have the same software priority level, the channel with lower number will get priority over the channel with higher number. For example, channel 2 gets priority over channel 4.

Note: The DMA1 controller has priority over the DMA2 controller.

#### 9.3.3 DMA Channels

Each channel can handle DMA transfer between a peripheral register located at a fixed address and a memory address. The amount of data to be transferred is programmable (up to 65535). The register which contains the amount of data items to be transferred is decremented after each transaction.



#### Programmable data size

The transferred data size of peripheral and memory can be programmed through the PWIDTH and MWIDTH bits in the DMA\_CHCTRLx register.

#### **Pointer incrementation**

By configuring the PINC and MINC flag bits in the DMA\_CHCTRLx register, peripheral and memory pointers can be selectively and automatically post-incremented after each transaction. If incremented mode is enabled, the next transfer address will be the previous address incremented by 1, 2, or 4, depending on the chosen data size. The first transfer address is the one programmed in the DMA\_CPBAx/DMA\_CMBAx registers. During transfer process, these registers keep their initially programmed values. The current transfer addresses (in the current internal peripheral/memory address register) cannot be modified by software.

If the channel is configured in non-circular mode, no DMA transaction will be generated after a transfer is completed (that is, the number of data items to be transferred has reached zero). To begin a new DMA transfer, write a new number of data items to be transferred into the DMA\_TCNTx register with the DMA channel disabled.

Note: If a DMA channel is disabled, the DMA registers will not be reset. The DMA channel registers (DMA\_CHCTRLx, DMA\_CPBAx, and DMA\_CMBAx) remain the values programmed previously.

In the circular mode, after the last transfer is completed, the DMA\_TCNTx register is automatically reloaded with the initially programmed value. The current internal peripheral/memory address register is also reloaded with the initial base address programmed by the DMA\_CPBAx/DMA\_CMBAx registers.

#### **Channel configuration process**

DMA channel x configuration procedure is as follows (where x is the channel number):

1. Set the peripheral register address in the DMA\_CPBAx register. Data will be transferred from/to this address when there is peripheral data transfer request.

2. Set the memory address in the DMA\_CMBAx register. Data will be read from/written to this address when there is peripheral data transfer request.

3. Configure the amount of data to be transferred in the DMA\_TCNTx register. After each data transfer, this value will be decremented.

4. Configure the channel priority by using the CHPL[1:0] bits in the DMA\_CHCTRLx register.



5. Configure data transfer direction, circular mode, peripheral/memory incremented mode, peripheral/memory data size, and interrupt after half or full transfer in the DMA\_CHCTRLx register.
6. Activate the channel by setting the ENABLE bit in the DMA\_CHCTRLx register.

Once the DMA channel is enabled, it can serve any DMA request from the peripheral connected to the channel.

After half of the data is transferred, the half-transfer flag (HTIF) is set. An interrupt is generated if the Half-Transfer Interrupt Enable bit (HTIE) is set. After the transfer is completed, the Transfer Complete Flag (TCIF) is set. An interrupt is generated if the Transfer Complete Interrupt Enable bit (TCIE) is set.

#### **Circular mode**

Circular mode is used to handle circular buffers and continuous data transfer (e.g. ADC scan mode). The CIRM bit in the DMA\_CHCTRLx register can be used to enable this function. Once the circular mode is activated, when the amount of data to be transferred becomes 0, it will automatically be reloaded with the initial value programmed at the channel configuration phase, and DMA transaction will continue.

#### Memory-to-memory mode

The DMA channels can also work without requests from peripherals. This mode is called memory-to-memory mode. If the MEMTOMEM bit in the DMA\_CHCTRLx register is set, DMA transfer begins as soon as software activates the DMA channel by setting the CHEN bit in the DMA\_CHCTRLx register.

DMA transfer stops once the DMA\_TCNTx register reaches zero. Memory-to-memory mode cannot be used with the circular mode at the same time.

# 9.3.4 Programmable Data Transfer Width, Alignment, and Endian

When PWIDTH is not equal to MWIDTH, DMA block performs data alignment according to Table 9-1.

| Course |                           | Number        | Source   |                    | Destination |
|--------|---------------------------|---------------|----------|--------------------|-------------|
| Source | Destination<br>Port Width | of Data       | Content: | Transfer Operation | Content:    |
| Port   |                           | Items to      | Address/ | Transfer Operation | Address/    |
| Width  |                           | Transfer Data |          |                    | Data        |

Table 9-1 Programmable Data Transfer Width and Endian Behavior (When PINC = MINC = 1)



| 8         8         4         1: Read B0[7:0] at 0x0, then<br>write B0[7:0] at 0x0         0x0/B0           8         8         4         0x1/B1         write B1[7:0] at 0x1, then<br>0x2/B2         0x1/B1           0x2/B2         3: Read B2[7:0] at 0x2, then<br>0x3/B3         0x1/B1         write B2[7:0] at 0x2, then<br>write B3[7:0] at 0x3, then<br>write B3[7:0] at 0x3, then         0x3/B1           8         16         4         0x0/B0         2: Read B1[7:0] at 0x1, then<br>write B0[15:0] at 0x2         0x2/00           8         16         4         0x0/B0         2: Read B1[7:0] at 0x2, then<br>write B0[15:0] at 0x2         0x2/00           8         16         4         0x0/B0         2: Read B1[7:0] at 0x1, then<br>write B0[15:0] at 0x4         0x0/00           8         16         4         0x3/B3         write B1[15:0] at 0x2, then<br>0x3/B3         0x1/B1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 31<br>32<br>33<br>0B0<br>0B1<br>0B2 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| 8         8         4         0x0/B0         2: Read B1[7:0] at 0x1, then         0x0/B           0x1/B1         write B1[7:0] at 0x1         0x1/B         0x1/B         0x1/B         0x1/B           0x2/B2         3: Read B2[7:0] at 0x2, then         0x2/B         0x3/B3         write B2[7:0] at 0x2, then         0x2/B           0x3/B3         write B2[7:0] at 0x3, then         0x3/B         write B3[7:0] at 0x3, then         0x3/B           8         16         4         0x0/B0         2: Read B1[7:0] at 0x2, then         0x0/00           8         16         4         0x0/B0         2: Read B1[7:0] at 0x2, then         0x0/00           0x1/B1         write B0[15:0] at 0x0         0x2/B2         3: Read B1[7:0] at 0x1, then         0x0/00           0x1/B1         write B1[15:0] at 0x2         0x2/00         0x2/B2         3: Read B2[7:0] at 0x2, then         0x4/00           0x3/B3         write B2[15:0] at 0x4         0x6/00         0x3/B3         write B2[15:0] at 0x3, then         0x4/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 31<br>32<br>33<br>0B0<br>0B1<br>0B2 |
| 8       8       4       0x1/B1       write B1[7:0] at 0x1       0x1/B1       0x1/B1         0x2/B2       3: Read B2[7:0] at 0x2, then       0x2/B         0x3/B3       write B2[7:0] at 0x2       0x3/B         4: Read B3[7:0] at 0x3, then       0x3/B         write B3[7:0] at 0x3       0x3         8       16       4         4       0x1/B1         write B1[7:0] at 0x2       0x3/B         9       0x0/B0       2: Read B1[7:0] at 0x0, then         write B0[15:0] at 0x0       0x2/B         0x1/B1       write B1[15:0] at 0x2       0x2/00         0x3/B3       write B1[15:0] at 0x2, then       0x4/00         0x3/B3       write B1[15:0] at 0x4       0x6/00         0x3/B3       write B2[15:0] at 0x3, then       0x6/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 31<br>32<br>33<br>0B0<br>0B1<br>0B2 |
| 8       8       4       0x2/B2       3: Read B2[7:0] at 0x2, then       0x2/B         0x3/B3       write B2[7:0] at 0x2       0x3/B         4: Read B3[7:0] at 0x3, then       0x3/B         write B3[7:0] at 0x3, then       write B3[7:0] at 0x3, then         8       16       4         4       0x0/B0       2: Read B1[7:0] at 0x1, then       0x0/00         0x1/B1       write B1[15:0] at 0x2       0x2/00         0x3/B3       write B1[15:0] at 0x2, then       0x4/00         0x3/B3       write B2[15:0] at 0x4       0x6/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 32<br>33<br>0B0<br>0B1<br>0B2       |
| 8         16         4         0x2/B2         3: Read B2[7:0] at 0x2, then         0x2/B2           0x3/B3         write B2[7:0] at 0x2         0x3/B         0x3/B         0x3/B         0x3/B           4: Read B3[7:0] at 0x3, then         write B3[7:0] at 0x3, then         write B3[7:0] at 0x3         0x3/B           8         16         4         0x0/B0         2: Read B1[7:0] at 0x2, then         0x0/00           0x1/B1         write B1[15:0] at 0x2         0x2/00         0x2/B2         3: Read B2[7:0] at 0x2, then         0x4/00           8         16         4         0x3/B3         write B1[15:0] at 0x2         0x2/00           8         16         4         0x3/B3         write B1[15:0] at 0x2, then         0x4/00           9         0x3/B3         write B2[15:0] at 0x3, then         0x6/00         4: Read B3[7:0] at 0x3, then         0x6/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 33<br>)B0<br>)B1<br>)B2             |
| 8       16       4       Read B3[7:0] at 0x3, then write B3[7:0] at 0x3         8       16       4       Read B0[7:0] at 0x0         8       16       4       0x0/B0       2: Read B1[7:0] at 0x1, then 0x0/00         0x1/B1       write B1[15:0] at 0x2       0x2/00         0x3/B3       write B2[15:0] at 0x4       0x6/00         4: Read B3[7:0] at 0x3, then       0x6/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | )B0<br>)B1<br>)B2                   |
| Image: Market instant         Image: Market instant | )B1<br>)B2                          |
| 8         16         4         1: Read B0[7:0] at 0x0, then<br>write B0[15:0] at 0x0         0x0/B0         2: Read B1[7:0] at 0x1, then         0x0/00           0x1/B1         write B1[15:0] at 0x2         0x2/00         0x2/00         0x2/00         0x2/00           0x3/B3         write B2[15:0] at 0x3, then         0x6/00         4: Read B3[7:0] at 0x3, then         0x6/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | )B1<br>)B2                          |
| 8         16         4         0x0/B0         2: Read B1[7:0] at 0x1, then         0x0/00           0x1/B1         write B1[15:0] at 0x2         0x2/00           0x2/B2         3: Read B2[7:0] at 0x2, then         0x4/00           0x3/B3         write B2[15:0] at 0x3, then         0x6/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | )B1<br>)B2                          |
| 8       16       4       0x0/B0       2: Read B1[7:0] at 0x1, then       0x0/00         0x1/B1       write B1[15:0] at 0x2       0x2/00         0x2/B2       3: Read B2[7:0] at 0x2, then       0x4/00         0x3/B3       write B2[15:0] at 0x4       0x6/00         4: Read B3[7:0] at 0x3, then       0x6/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | )B1<br>)B2                          |
| 8       16       4       0x1/B1       write B1[15:0] at 0x2       0x2/00         0x2/B2       3: Read B2[7:0] at 0x2, then       0x4/00         0x3/B3       write B2[15:0] at 0x4       0x6/00         4: Read B3[7:0] at 0x3, then       0x6/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | )B1<br>)B2                          |
| 8         16         4         0x2/B2         3: Read B2[7:0] at 0x2, then         0x4/00           0x3/B3         write B2[15:0] at 0x4         0x6/00           4: Read B3[7:0] at 0x3, then         0x6/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | )B2                                 |
| 0x2/B2         3: Read B2[7:0] at 0x2, then         0x4/00           0x3/B3         write B2[15:0] at 0x4         0x6/00           4: Read B3[7:0] at 0x3, then         0x6/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                     |
| 4: Read B3[7:0] at 0x3, then                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | )B3                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                     |
| write B3[15:0] at 0x6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                     |
| 1: Read B0[7:0] at 0x0, then                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                     |
| write 000000B0[31:0] at 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                     |
| 0x0/B0 2: Read B1[7:0] at 0x1, then 0x0/0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | )00B0                               |
| 0x1/B1         write 000000B1[31:0] at 0x4         0x4/0000           8         32         4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | )00B1                               |
| 0x2/B2 3: Read B2[7:0] at 0x2, then 0x8/0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | )00B2                               |
| 0x3/B3 write 000000B2[31:0] at 0x8 0xC/0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | )00B3                               |
| 4: Read B3[7:0] at 0x3, then                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                     |
| write 000000B3[31:0] at 0xC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                     |
| 1: Read B1B0[15:0] at 0x0, then                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                     |
| write B0[7:0] at 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                     |
| 0x0/B1B0 2: Read B3B2[15:0] at 0x2, then 0x0/B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 30                                  |
| 16         8         4         0x2/B3B2         write B2[7:0] at 0x1         0x1/E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 32                                  |
| 0x4/B5B4 3: Read B5B4[15:0] at 0x4, then 0x2/E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 34                                  |
| 0x6/B7B6 write B4[7:0] at 0x2 0x3/E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 36                                  |
| 4: Read B7B6[15:0] at 0x6, then                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                     |
| write B6[7:0] at 0x3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                     |



|    |    |   |                                 | 1: Read B1B0[15:0] at 0x0, then |              |
|----|----|---|---------------------------------|---------------------------------|--------------|
|    |    |   |                                 | write B1B0[15:0] at 0x0         |              |
|    |    |   | 0x0/B1B0                        | 2: Read B3B2[15:0] at 0x2, then | 0x0/B1B0     |
| 16 | 16 | 4 | 0x2/B3B2                        | write B3B2[15:0] at 0x2         | 0x2/B3B2     |
| 10 | 10 | 4 | 0x4/B5B4                        | 3: Read B5B4[15:0] at 0x4, then | 0x4/B5B4     |
|    |    |   | 0x6/B7B6                        | write B5B4[15:0] at 0x4         | 0x6/B7B6     |
|    |    |   | 4: Read B7B6[15:0] at 0x6, then |                                 |              |
|    |    |   |                                 | write B7B6[15:0] at 0x6         |              |
|    |    |   |                                 | 1: Read B1B0[15:0] at 0x0, then |              |
|    |    |   |                                 | write 0000B1B0[31:0] at 0x0     |              |
|    |    |   | 0x0/B1B0                        | 2: Read B3B2[15:0] at 0x2, then | 0x0/0000B1B0 |
| 16 | 32 | 4 | 0x2/B3B2                        | write 0000B3B2[31:0] at 0x4     | 0x4/0000B3B2 |
| 10 | 32 | 4 | 0x4/B5B4                        | 3: Read B5B4[15:0] at 0x4, then | 0x8/0000B5B4 |
|    |    |   | 0x6/B7B6                        | write 0000B5B4[31:0] at 0x8     | 0xC/0000B7B6 |
|    |    |   |                                 | 4: Read B7B6[15:0] at 0x6, then |              |
|    |    |   |                                 | write 0000B7B6[31:0] at 0xC     |              |
|    | 8  | 4 | 0x0/B3B                         | 1: Read B3B2B1B0[31:0] at       |              |
|    |    |   | 2B1B0                           | 0x0, then write B0[7:0] at 0x0  |              |
|    |    |   | 0x4/B7B                         | 2: Read B7B6B5B4[31:0] at       | 0x0/B0       |
|    |    |   | 6B5B4                           | 0x4, then write B4[7:0] at 0x1  | 0x1/B4       |
| 32 |    |   |                                 |                                 |              |
|    |    |   | 0x8/BBB                         | 3: Read BBBAB9B8[31:0] at       | 0x2/B8       |
|    |    |   | AB9B8                           | 0x8, then write B8[7:0] at 0x2  | 0x3/BC       |
|    |    |   | 0xC/BFB                         | 4: Read BFBEBDBC[31:0] at       |              |
|    |    |   | EBDBC                           | 0xC, then write BC[7:0] at 0x3  |              |
|    |    |   | 0x0/B3B                         | 1: Read B3B2B1B0[31:0] at       |              |
|    |    |   | 2B1B0                           | 0x0, then write B1B0[15:0] at   | 0x0/B1B0     |
|    |    |   | 0x4/B7B                         | 0x0                             | 0x2/B5B4     |
| 32 | 16 | 4 | 6B5B4                           |                                 |              |
|    |    |   | 00004                           | 2: Read B7B6B5B4[31:0] at       | 0x4/B9B8     |
|    |    |   | •                               | 0x4, then write B5B4[15:0] at   |              |
|    |    |   | 0x8/BBB                         | 0x2                             | 0x6/BDBC     |



|    |    |   | 0xC/BFB<br>EBDBC                                                             | 3: Read BBBAB9B8[31:0] at<br>0x8, then write B9B8[15:0] at<br>0x4<br>4: Read BFBEBDBC[31:0] at<br>0xC, then write BDBC[15:0] at<br>0x6                                                                                                                                                         |                                                                              |
|----|----|---|------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| 32 | 32 | 4 | 0x0/B3B<br>2B1B0<br>0x4/B7B<br>6B5B4<br>0x8/BBB<br>AB9B8<br>0xC/BFB<br>EBDBC | 1: Read B3B2B1B0[31:0] at<br>0x0, then write B3B2B1B0[31:0]<br>at 0x0<br>2: Read B7B6B5B4[31:0] at<br>0x4, then write B7B6B5B4[31:0]<br>at 0x4<br>3: Read BBBAB9B8[31:0] at<br>0x8, then write BBBAB9B8[31:0]<br>at 0x8<br>4: Read BFBEBDBC[31:0] at 0xC,<br>then write BFBEBDBC[31:0] at 0xC, | 0x0/B3B2B1B<br>0<br>0x4/B7B6B5B<br>4<br>0x8/BBBAB9B<br>8<br>0xC/BFBEBDB<br>C |

#### Addressing an AHB peripheral that does not support byte or half-word write operations

When the DMA block initiates an AHB byte or half-word write operation, the data are duplicated on the unused lanes of the HWDATA[31:0] bus. Therefore, when DMA writes byte or half-word to the AHB peripheral that does not support byte or half-word write operations (when HSIZE is not used by the peripheral), errors will not be generated. The DMA writes the 32-bit HWDATA in the manner shown in the following two examples:

• To write the half-word "0xABCD'' when HSIZE = half-word, the DMA sets the HWDATA bus to "0xABCDABCD''.

• To write the byte "0xAB'' when HSIZE = byte, the DMA sets the HWDATA bus to "0xABABABAB'.

If the AHB/APB bridge is an AHB 32-bit slave peripheral that does not take the HSIZE data into account, it will transform any AHB byte or half-word operation into 32-bit APB operation in the following manner:



• An AHB byte write operation of the data "0xB0" to 0x0 (or to 0x1, 0x2 or 0x3) will be converted to an APB word write operation of the data "0xB0B0B0B0" to 0x0.

• An AHB half-word write operation of the data "0xB1B0" to 0x0 (or to 0x2) will be converted to an APB word write operation of the data "0xB1B0B1B0" to 0x0 .

For instance, to write the APB backup registers (16-bit registers aligned to a 32-bit address boundary), the memory data source width (MWIDTH) must be configured to "16 bits", and the peripheral data destination width (PWIDTH) to "32 bits".

#### 9.3.5 Error Management

A DMA transfer error can be generated when reading from or writing to a reserved address space. When a DMA transfer error occurs during a DMA read or a write access, the CHEN bit of in the channel configuration register (DMA\_CHCTRLx) corresponding to the faulty channel will be cleared automatically by hardware, and the operation on the channel is disabled. At this time, the transfer error interrupt flag bit (ERRIF) corresponding to the channel in the DMA\_IFR register is set. An interrupt is generated if the transfer error interrupt enable bit in the DMA\_CHCTRLx register is set.

#### 9.3.6 Interrupts

An interrupt can be generated on a DMA half transfer, transfer complete, or transfer error form each DMA channel. For the purpose of flexibility, interrupts are enabled by configuring different bits in the registers.

Table 9-2 DMA Interrupt Request

| Interrupt Event    | Event Flag Bit | Enable Control Bit |
|--------------------|----------------|--------------------|
| Half transfer      | HTIF           | HTIE               |
| Transfer completed | TCIF           | TCIE               |
| Transfer error     | ERRIF          | ERRIE              |

Note: DMA2 channel 4 and DMA2 channel 5 interrupts are mapped onto the same interrupt vector.

#### 9.3.7 DMA Request Mapping

#### DMA1 Controller



The 7 requests from the peripherals (TMRx[1,2,3,4], ADC1, SPI1, SPI/I2S2, I<sup>2</sup>Cx[1,2], and USARTx[1,2,3]) are logically ORed before entering the DMA1 controller, and this means that only one request can be enabled at a time. Please refer to Figure 9-2 for DMA1 request mapping.

The peripheral DMA requests can be independently activated/ de-activated by programming the control bit in the corresponding peripheral registers.

Figure 9-2 DMA1 Request Mapping





| Peripheral | Channel 1 | Channel 2    | Channel 3    | Channel 4    | Channel 5    | Channel 6 | Channel 7 |
|------------|-----------|--------------|--------------|--------------|--------------|-----------|-----------|
| ADC1       | ADC1      |              |              |              |              |           |           |
| SPI/I2S    |           | SPI1/I2S1_RX | SPI1/I2S1_TX | SPI2/I2S2_RX | SPI2/I2S2_TX |           |           |
| USART      |           | USART3_TX    | USART3_RX    | USART1_TX    | USART1_RX    | USART2_RX | USART2_TX |
| 12C        |           | I2C3_TX      | I2C3_RX      | I2C2_TX      | I2C2_RX      | I2C1_TX   | I2C1_RX   |
| TMR1       |           | TMR1_CH1     | TMR1_CH2     | TMR1_CH4     | TMR1_UP      | TMR1_CH3  |           |
|            |           |              |              | TMR1_TRIG    |              |           |           |
|            |           |              |              | TMR1_COM     |              |           |           |
| TMR2       | TMR2_CH3  | TMR2_UP      |              |              | TMR2_CH1     |           | TMR2_CH2  |
|            |           |              |              |              |              |           | TMR2_CH4  |
| TMR3       |           | TMR3_CH3     | TMR3_CH4     |              |              | TMR3_CH1  |           |
|            |           |              | TMR3_UP      |              |              | TMR3_TRIG |           |
| TMR4       | TMR4_CH1  |              |              | TMR4_CH2     | TMR4_CH3     |           | TMR4_UP   |

#### Table 9-3 Summary of DMA1 Requests for Each Channel

#### **DMA2** Controller

The 5 requests from the peripherals (TMRx[5, 8], UART4、SPI3、SPI4) are logically ORed and sent to the DMA2, and this means that only one request can be enabled at a time. Please refer to Figure 9-3 for DMA2 requests mapping.

The peripheral DMA requests can be independently activated/de-activated by programming the control bit in the corresponding peripheral registers.

Figure 9-3 DMA2 Request Mapping





| Peripheral | Channel 1             | Channel 2                         | Channel 3    | Channel 4    | Channel 5 |
|------------|-----------------------|-----------------------------------|--------------|--------------|-----------|
| SPI        | SPI3/I2S3_RX          | SPI3/I2S3_TX                      | SPI4/I2S4_RX | SPI4/I2S4_TX |           |
| UART4      |                       |                                   | UART4_RX     |              | UART4_TX  |
| TMR5       | TMR5_CH4<br>TMR5_TRIG | TMR5_CH3<br>TMR5_UP               |              | TMR5_CH2     | TMR5_CH1  |
| TMR6       |                       |                                   | TMR6_UP      |              |           |
| TMR7       |                       |                                   |              | TMR7_UP      |           |
| TMR8       | TMR8_CH3<br>TMR8_UP   | TMR8_CH4<br>TMR8_TRIG<br>TMR8_COM | TMR8_CH1     |              | TMR8_CH2  |



### 9.3.8 DMA Flexible Request Mapping

When DMA\_FLEX\_EN is set to flexible mode, request source of each channel is set by CHx\_SRC, [x = 1, 2, 3, 4, 5, 6, 7]. Table 9-5 shows the corresponding DMA source of CHx\_SRC value:

|         |            |         |            |         |            |         | ]          |
|---------|------------|---------|------------|---------|------------|---------|------------|
| CHx_SRC | DMA source |
| value   |            | value   |            | value   |            | value   |            |
| 0       | No select  | 1       | ADC1       | 2       | reserved   | 3       | reserved   |
| 4       | reserved   | 5       | reserved   | 6       | reserved   | 7       | reserved   |
| 8       | reserved   | 9       | SPI1_RX    | 10      | SPI1_TX    | 11      | SPI2_RX    |
| 12      | SPI2_TX    | 13      | SPI3_RX    | 14      | SPI3_TX    | 15      | SPI4_RX    |
| 16      | SPI4_TX    | 17      | reserved   | 18      | reserved   | 19      | reserved   |
| 20      | reserved   | 21      | reserved   | 22      | reserved   | 23      | reserved   |
| 24      | reserved   | 25      | USART1_RX  | 26      | USART1_TX  | 27      | USART2_RX  |
| 28      | USART2_TX  | 29      | USART3_RX  | 30      | USART3_TX  | 31      | UART4_RX   |
| 32      | UART4_TX   | 33      | UART5_RX   | 34      | UART5_TX   | 35      | USART6_RX  |
| 36      | USART6_TX  | 37      | UART7_RX   | 38      | UART7_TX   | 39      | UART8_RX   |
| 40      | UART8_TX   | 41      | I2C1_RX    | 42      | I2C1_TX    | 43      | I2C2_RX    |
| 44      | I2C2_TX    | 45      | I2C3_RX    | 46      | I2C3_TX    | 47      | reserved   |
| 48      | reserved   | 49      | 1          | 50      | 2          | 51      | reserved   |
| 52      | reserved   | 53      | TMR1_TRIG  | 54      | TMR1_COM   | 55      | TMR1_UP    |
| 56      | TMR1_CH1   | 57      | TMR1_CH2   | 58      | TMR1_CH3   | 59      | TMR1_CH4   |
| 60      | reserved   | 61      | TMR2_TRIG  | 62      | reserved   | 63      | TMR2_UP    |
| 64      | TMR2_CH1   | 65      | TMR2_CH2   | 66      | TMR2_CH3   | 67      | TMR2_CH4   |
| 68      | reserved   | 69      | TMR3_TRIG  | 70      | reserved   | 71      | TMR3_UP    |
| 72      | TMR3_CH1   | 73      | TMR3_CH2   | 74      | TMR3_CH3   | 75      | TMR3_CH4   |
| 76      | reserved   | 77      | TMR4_TRIG  | 78      | reserved   | 79      | TMR4_UP    |

Table 9-5 DMA Flexible Request of each Channel



| 80  | TMR4_CH1 | 81  | TMR4_CH2  | 82  | TMR4_CH3 | 83  | TMR4_CH4 |
|-----|----------|-----|-----------|-----|----------|-----|----------|
| 84  | reserved | 85  | TMR5_TRIG | 86  | reserved | 87  | TMR5_UP  |
| 88  | TMR5_CH1 | 89  | TMR5_CH2  | 90  | TMR5_CH3 | 91  | TMR5_CH4 |
| 92  | reserved | 93  | reserved  | 94  | reserved | 95  | TMR6_UP  |
| 96  | reserved | 97  | reserved  | 98  | reserved | 99  | reserved |
| 100 | reserved | 101 | reserved  | 102 | reserved | 103 | TMR7_UP  |
| 104 | reserved | 105 | reserved  | 106 | reserved | 107 | reserved |
| 108 | reserved | 109 | TMR8_TRIG | 110 | TMR8_COM | 111 | TMR8_UP  |
| 112 | TMR8_CH1 | 113 | TMR8_CH2  | 114 | TMR8_CH3 | 115 | TMR8_CH4 |
| 116 | reserved | 117 | reserved  | 118 | reserved | 119 | reserved |
| 120 | reserved | 121 | reserved  | 122 | reserved | 123 | reserved |
| 124 | reserved | 125 | reserved  | 126 | reserved | 127 | reserved |
| 128 | reserved | 129 | reserved  | 130 | reserved | 131 | reserved |
| 132 | reserved | 133 | reserved  | 134 | reserved | 135 | reserved |
| 136 | reserved | 137 | reserved  | 138 | reserved | 139 | reserved |
| 140 | reserved | 141 | reserved  | 142 | reserved | 143 | reserved |
| 144 | reserved | 145 | reserved  | 146 | reserved | 147 | reserved |
| 148 | reserved | 149 | reserved  | 150 | reserved | 151 | reserved |
| 152 | reserved | 153 | reserved  | 154 | reserved | 155 | reserved |
| 156 | reserved | 157 | reserved  | 158 | reserved | 159 | reserved |
| 160 | reserved | 161 | reserved  | 162 | reserved | 163 | reserved |
| 164 | reserved | 165 | reserved  | 166 | reserved | 167 | reserved |
| 168 | reserved | 169 | reserved  | 170 | reserved | 171 | reserved |
| 172 | reserved | 173 | reserved  | 174 | reserved | 175 | reserved |

When DMA1/2 DMA\_FLEX\_EN should be set to 1 or 0 at the same time, DMA1/2 mapping mode should be consistent; hence, when DMA1 is fixed mapping, DMA2 cannot be flexible mapping.



For example, if DMA channel 1 is to designate USART3\_TX, channel 3 should designate USART3\_RX, and others are not used, then the setting should be DMA\_FLEX\_EN = 1, CH1\_SRC = 30, CH3\_SRC = 29, and  $CH[2/4/5/6/7]_SRC = 0$ .

## 9.4 DMA Registers

The peripheral registers can be accessed by bytes (8-bit), half-words (16-bit), or words (32-bit).

Note: In the following registers, all bits related to channel 6 and channel 7 are not relevant for DMA2 since it has only 5 channels. For the flexible request image of DMA2, it can support up to 7 channels.

#### 9.4.1 DMA Interrupt Status Register (DMA\_ISTS)

Address offset: 0x00

| Bit         | Name   | Туре | Description                                           |
|-------------|--------|------|-------------------------------------------------------|
| Bit 31:28   | -      | -    | Reserved. Always read as 0.                           |
| Bit 27, 23, | ERRIFx | r    | Channel x transfer error flag (x = 1 7)               |
| 19, 15, 11, |        |      | These bits are set by hardware. Writing '1' to the    |
| 7, 3        |        |      | corresponding bit of DMA_ICLR register can clear the  |
|             |        |      | corresponding flag bit here.                          |
|             |        |      | 0: No transfer error (TE) occurred on channel x.      |
|             |        |      | 1: Transfer error (TE) occurred on channel x.         |
| Bit 26, 22, | HTIFx  | r    | Channel x half transfer flag (x = 1 7)                |
| 18, 14, 10, |        |      | These bits are set by hardware. Writing $1'$ to the   |
| 6, 2        |        |      | corresponding bit of DMA_ICLR register can clear the  |
|             |        |      | corresponding flag bit here.                          |
|             |        |      | 0: No half transfer (HT) event occurred on channel x. |
|             |        |      | 1: Half transfer (HT) event occurred on channel x.    |



| Bit 25, 21, | TCIFx | r | Channel x transfer complete flag (x = 1 7)                |
|-------------|-------|---|-----------------------------------------------------------|
| 17, 13, 9,  |       |   | These bits are set by hardware. Writing `1' to the        |
| 5, 1        |       |   | corresponding bit of DMA_ICLR register can clear the      |
|             |       |   | corresponding flag bit here.                              |
|             |       |   | 0: No transfer complete (TC) event occurred on channel x. |
|             |       |   | 1: Transfer complete (TC) event occurred on channel x.    |
| Bit 24, 20, | GIFx  | r | Channel x global interrupt flag (x = 1 7)                 |
| 16, 12, 8,  |       |   | These bits are set by hardware. Writing `1' to the        |
| 4,0         |       |   | corresponding bit of DMA_ICLR register can clear the      |
|             |       |   | corresponding flag bit here.                              |
|             |       |   | 0: No TE, HT, or TC events occurred on channel x.         |
|             |       |   | 1: TE, HT, or TC events occurred on channel x.            |

### 9.4.2 DMA Interrupt Flag Clear Register (DMA\_ICLR)

Address offset: 0x04

| Bit         | Name    | Туре | Description                                                        |
|-------------|---------|------|--------------------------------------------------------------------|
| Bit 31:28   | -       | -    | Reserved. Always read as 0.                                        |
| Bit 27, 23, | CERRIFx | rw   | Channel x transfer error clear (x = 1 7) These bits are set and    |
| 19, 15,     |         |      | cleared by software.                                               |
| 11, 7, 3    |         |      | 0: No effect                                                       |
|             |         |      | 1: Clear the corresponding ERRIF flag in the DMA_ISTS register     |
| Bit 26, 22, | CHTIFx  | rw   | Channel x half transfer clear (x = 1 7) These bits are set and     |
| 18, 14, 10, |         |      | cleared by software.                                               |
| 6, 2        |         |      | 0: No effect                                                       |
|             |         |      | 1: Clear the corresponding HTIF flag in the DMA_ISTS register      |
| Bit 25, 21, | CTCIFx  | rw   | Channel x transfer complete clear (x = 1 7) These bits are set and |
| 17,13,      |         |      | cleared by software.                                               |
| 9, 5, 1     |         |      | 0: No effect                                                       |
|             |         |      | 1: Clear the corresponding TCIF flag in the DMA_ISTS register      |



| Bit 24, 20, | CGIFx | rw | Channel x global interrupt clear (x = 1 7) These bits are set and  |
|-------------|-------|----|--------------------------------------------------------------------|
| 16, 12, 8,  |       |    | cleared by software.                                               |
| 4,0         |       |    | 0: No effect                                                       |
|             |       |    | 1: Clear the corresponding GIF, ERRIF, HTIF, and TCIF flags in the |
|             |       |    | DMA_ISTS register                                                  |

## 9.4.3 DMA Channel x Configuration Register

### (DMA\_CHCTRLx) (x = 1 ... 7)

Address offset: 0x08 + 20 x (channel number - 1)

| Bit       | Name        | Туре | Description                                                                                                                                       |
|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:15 | -           | -    | Reserved. Always read as 0.                                                                                                                       |
| Bit 14    | MEMTOMEM    | rw   | Memory-to-memory model. This bit is set and cleared by software.<br>0: Memory-to-memory mode is disabled.<br>1: Memory-to-memory mode is enabled. |
| Bit 13:12 | CHPL[1:0]   | rw   | Channel priority level<br>These bits are set and cleared by software.<br>00: Low<br>01: Medium<br>10: High<br>11: Very high                       |
| Bit 11:10 | MWIDTH[1:0] | rw   | Memory size<br>These bits are set and cleared by software.<br>00: 8 bits<br>01: 16 bits<br>10: 32 bits<br>11: Reserved                            |
| Bit 9:8   | PWIDTH[1:0] | rw   | Peripheral size<br>These bits are set and cleared by software.<br>00: 8 bits                                                                      |



|                                                |       |                             | 01: 16 bits                                                              |
|------------------------------------------------|-------|-----------------------------|--------------------------------------------------------------------------|
|                                                |       |                             | 10: 32 bits                                                              |
|                                                |       |                             | 11: Reserved                                                             |
|                                                |       |                             | Memory increment mode                                                    |
|                                                |       |                             | This bit is set and cleared by software.                                 |
| Bit 7                                          | MINC  | rw                          | 0: Memory increment mode is disabled.                                    |
|                                                |       |                             | 1: Memory increment mode is enabled.                                     |
|                                                |       |                             | Peripheral increment mode This bit is set and cleared by software.       |
| Bit 6                                          | PINC  | rw                          | 0: Peripheral increment mode is disabled.                                |
|                                                |       |                             | 1: Peripheral increment mode is enabled.                                 |
|                                                |       |                             | Circular mode                                                            |
|                                                |       |                             | This bit is set and cleared by software.                                 |
| Bit 5                                          | CIRM  | rw                          | 0: Circular mode is disabled.                                            |
|                                                |       |                             | 1: Circular mode is enabled.                                             |
|                                                |       |                             | Data transfer direction                                                  |
|                                                | DID   |                             | This bit is set and cleared by software.                                 |
| Bit 4                                          | DIR   | rw                          | 0: Read from peripheral                                                  |
|                                                |       |                             | 1: Read from memory                                                      |
|                                                |       |                             | Transfer error interrupt enable This bit is set and cleared by software. |
| Bit 3                                          | ERRIE | rw                          | 0: TE interrupt is disabled.                                             |
|                                                |       |                             | 1: TE interrupt is enabled.                                              |
|                                                |       |                             | Half transfer interrupt enable This bit is set and cleared by software.  |
| Bit 2                                          | HTIE  | rw                          | 0: HT interrupt is disabled.                                             |
|                                                |       |                             | 1: HT interrupts is enabled.                                             |
|                                                |       |                             | Transfer complete interrupt enable This bit is set and cleared by        |
|                                                |       |                             | software.                                                                |
| Bit 1                                          | TCIE  | rw                          | 0: TC interrupt is disabled.                                             |
|                                                |       | 1: TC interrupt is enabled. |                                                                          |
|                                                |       |                             | Channel enable                                                           |
| Bit 0                                          | CHEN  | rw                          | This bit is set and cleared by software.                                 |
|                                                |       |                             | 0: Channel is disabled.                                                  |
| AngoHangzhou Vango Technologies, Inc.214 / 782 |       |                             |                                                                          |

## 9.4.4 DMA Channel x Number of Data Register (DMA\_TCNTx) (x = 1 ... 7)

Address offset: 0x0C + 20 x (channel number - 1)

Reset value: 0x0000 0000

| Bit       | Name      | Туре | Description                                                        |
|-----------|-----------|------|--------------------------------------------------------------------|
| Bit 31:16 | -         | -    | Reserved. Always read as 0.                                        |
|           |           |      | Number of data to transfer                                         |
|           |           |      | The number of data to be transferred is from 0 up to 65535. This   |
|           |           |      | register can only be written when the channel is disabled (CHEN =  |
|           |           |      | 0 in the DMA_CHCTRLx register). Once the channel is enabled, this  |
|           |           |      | register is read-only, indicating how many transfers remain. This  |
| Bit 15:0  | CNT[15:0] | rw   | register decrements after each DMA transfer.                       |
|           |           |      | After the transfer is completed, this register becomes '0'; if the |
|           |           |      | channel is configured in auto-reload mode, the register will be    |
|           |           |      | reloaded automatically by the value previously programmed.         |
|           |           |      | If this register is '0', no data transaction will be proceeded no  |
|           |           |      | matter the channel is enabled or not.                              |

## 9.4.5 DMA Channel x Peripheral Address Register (DMA\_CPBAx) (x = 1 ... 7)

Address offset: 0x10 + 20 x (channel number - 1)

Reset value: 0x0000 0000

When the channel is enabled (CHEN = 1 in the DMA\_CHCTRLx register), this register cannot be written.

| Bit      | Name     | Туре | Description        |
|----------|----------|------|--------------------|
| Bit 31:0 | PA[31:0] | rw   | Peripheral address |



|  | Base address of peripheral data register is the source or            |
|--|----------------------------------------------------------------------|
|  | destination for data transfer. When $PWIDTH = 01'$ (16 bits), the    |
|  | PA[0] bit is ignored. Access is automatically aligned to a half-word |
|  | address.                                                             |
|  | When PWIDTH = $10'$ (32 bits), PA[1:0] are ignored. Access is        |
|  | automatically aligned to a word address.                             |

## 9.4.6 DMA Channel x Memory Address Register (DMA\_CMBAx) (x = 1 ... 7)

Address offset:  $0x14 + 20 \times (\text{channel number} - 1)$ 

Reset value: 0x0000 0000

| Bit      | Name     | Туре | Description                                                                                                                                                                                                                                                                                                        |
|----------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | MA[31:0] | rw   | Memory address<br>Memory address is the source or destination for data transfer.<br>When MWIDTH = '01' (16 bits), the MA[0] bit is ignored. Access is<br>automatically aligned to a half-word address.<br>When MWIDTH = '10' (32 bits), MA[1:0] are ignored. Access is<br>automatically aligned to a word address. |

### 9.4.7 Channel Source Register 0 (DMA\_SRC\_SEL0)

Address offset: 0xA0

| Bit       | Name    | Туре | Description                                                                                             |
|-----------|---------|------|---------------------------------------------------------------------------------------------------------|
| Bit 31:24 | CH4_SRC | rw   | CH4 source selection bit<br>When DMA_FLEX_EN = 1, CH4_SRC selects CH4 source; please<br>refer to 9.3.8. |
| Bit 23:16 | CH3_SRC | rw   | CH3 source selection bit                                                                                |
| Hango Ha  |         | На   | ngzhou Vango Technologies, Inc. 216 / 782                                                               |

|          |         |    | When DMA_FLEX_EN = 1, CH3_SRC selects CH3 source; please                                                        |
|----------|---------|----|-----------------------------------------------------------------------------------------------------------------|
|          |         |    | refer to Section 9.3.8.                                                                                         |
| Bit 15:8 | CH2_SRC | rw | CH2 source selection bit<br>When DMA_FLEX_EN = 1, CH2_SRC selects CH2 source; please<br>refer to Section 9.3.8. |
| Bit 7:0  | CH1_SRC | rw | CH1 source selection bit<br>When DMA_FLEX_EN = 1, CH1_SRC selects CH1 source; please<br>refer to Section 9.3.8. |

# 9.4.8 Channel Source Register 1 (DMA\_SRC\_SEL1)

Address offset: 0xA4

Reset value: 0x0000 0000

| Bit       | Name        | Туре | Description                                                                                                                                                       |  |  |  |
|-----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit 31:25 | -           | -    | Reserved.                                                                                                                                                         |  |  |  |
| Bit 24    | DMA_FLEX_EN | rw   | <ul><li>DMA request mapping mode selection bit</li><li>0: DMA request mapping mode is fixed mode.</li><li>1: DMA request mapping mode is flexible mode.</li></ul> |  |  |  |
| Bit 23:16 | CH7_SRC     | rw   | CH7 source selection bit<br>When DMA_FLEX_EN = 1, CH7_SRC selects CH7 source; please<br>refer to Section 9.3.8.                                                   |  |  |  |
| Bit 15:8  | CH6_SRC     | rw   | CH6 source selection bit<br>When DMA_FLEX_EN = 1, CH6_SRC selects CH6 source; please<br>refer to Section 9.3.8.                                                   |  |  |  |
| Bit 7:0   | CH5_SRC     | rw   | CH5 source selection bit<br>When DMA_FLEX_EN = 1, CH5_SRC selects CH5 source; please<br>refer to Section 9.3.8.                                                   |  |  |  |



# **10** Timer

V84XXX timers include basic timers, general-purpose timers, and advanced-control timers. Please refer to Section 10.1 ~ Section 10.4 for the detailed function modes. All functions of different timers are shown in the following tables.

| Timer<br>Type                 | Timer                            | Counter<br>Bit | Count<br>mode      | Repetition |              | DMA<br>Requests | Capture/<br>compare<br>Channel |   | ETR<br>Input | Break<br>Input |
|-------------------------------|----------------------------------|----------------|--------------------|------------|--------------|-----------------|--------------------------------|---|--------------|----------------|
| Advanced-<br>control<br>timer | TMR1<br>TMR8                     | 16             | Up Down<br>Up/Down | 8-bit      | 1 ~<br>65536 | 0               | 4                              | 0 | 0            | 0              |
|                               | TMR2<br>TMR5                     | 16/32          | Up Down<br>Up/Down | Х          | 1 ~<br>65536 | 0               | 4                              | 0 | 0            | x              |
| General-                      | TMR3<br>TMR4                     | 16             | Up Down<br>Up/Down | Х          | 1 ~<br>65536 | Ο               | 4                              | 0 | 0            | x              |
| purpose                       | TMR9<br>TMR12                    | 16             | Up                 | х          | 1 ~<br>65536 | x               | 2                              | 0 | х            | x              |
|                               | TMR10<br>TMR11<br>TMR13<br>TMR14 | 16             | Up                 | х          | 1 ~<br>65536 | x               | 1                              | х | х            | x              |
| Basic<br>timer                | TMR6<br>TMR7                     | 16             | Up                 | х          | 1 ~<br>65536 | 0               | Х                              | х | х            | x              |

| Timer Type           | Timer                             | Counter Bit | Count Mode         | PWM | Output | Single Pulse | Complementary | Dead-time | Encoder | Interface | Interfacing with | Linkage           | Peripheral |
|----------------------|-----------------------------------|-------------|--------------------|-----|--------|--------------|---------------|-----------|---------|-----------|------------------|-------------------|------------|
| Advanced-<br>control | TMR1<br>TMR8                      | 16          | Up Down<br>Up/Down | C   | )      | 0            | 0             | 0         |         | 0         | 0                | Timer<br>synchron | ization    |
| ang                  | Hangzhou Vango Technologies, Inc. |             |                    |     |        |              |               |           | 21      | l8 / 782  |                  |                   |            |

| timer                        |                                  |       |                    |   |   |   |   |   |   |                                 |
|------------------------------|----------------------------------|-------|--------------------|---|---|---|---|---|---|---------------------------------|
|                              | TMR2<br>TMR5                     | 16/32 | Up Down<br>Up/Down | 0 | 0 | х | х | 0 | 0 | Timer<br>synchronization        |
|                              | TMR3<br>TMR4                     | 16    | Up Down<br>Up/Down | 0 | 0 | x | х | 0 | 0 | Timer<br>synchronization        |
| General-<br>purpose<br>timer | TMR9<br>TMR12                    | 16    | Up                 | 0 | 0 | х | Х | х | x | Timer<br>synchronization<br>ADC |
|                              | TMR10<br>TMR11<br>TMR13<br>TMR14 | 16    | Up                 | 0 | 0 | x | x | х | x | х                               |
| Basic timer                  | TMR6<br>TMR7                     | 16    | Up                 | х | x | x | х | х | x | х                               |

# 10.1 Basic Timer (TMR6 and TMR7)

# 10.1.1 TMR6 and TMR7 Introduction

Basic timers TMR6 and TMR7 consist of a 16-bit auto-reload counter driven by their own programmable prescaler, respectively. They can be used as general-purpose timers to provide time base.

The two timers are completely independent with each other and do not share any resources.

# 10.1.2 TMR6 and TMR7 Main Features

The main features of TMR6 and TMR7 include:

- 16-bit auto-reload up counter
- 16-bit programmable prescaler (can be modified on the fly) used to divide the input clock

frequency by any factor between 1  $\,\sim\,65536$ 

• Interrupt/DMA request on update event (counter flow)



Figure 10-1 Basic Timer Block Diagram



### 10.1.3 TMR6 and TMR7 Function Overview

#### 10.1.3.1 Time-base Unit

This programmable timer mainly consists of a 16-bit up counter with auto-reload function. The counter clock is obtained through a prescaler.

The counter, the auto-reload register, and the prescaler register can be written or read by software. This is even true when the counter is running.

The time-base unit includes:

- Counter register (TMRx\_CNT)
- Prescaler register (TMRx\_DIV)
- Auto-reload register (TMRx\_AR)

The auto-reload register is preloaded. Each read or write to the auto-reload register is achieved by writing or reading the preload register. The contents written to the preload register are transferred into its shadow register immediately or at each update event according to the auto-reload preload enable bit (ARPEN) in the TMRx\_CTRL1 register. When the UEVDIS bit in the TMRx\_CTRL1 register is '0', update



events will be generated by hardware once the counter reaches the overflow value. Update events can also be generated by software; please refer to the following sections for the detailed introduction on generation of the update events.

The counter is driven by the prescaler output, CK\_CNT, and it is enabled when the counter enable bit (CNTEN) in the TMRx\_CTRL1 register is set.

Note: The actual counter enable signal, CNT\_EN, is set 1 clock cycle after CNTEN is set.

### 10.1.3.2 Prescaler

The prescaler can divide the counter clock frequency by any factor between  $1 \sim 65536$ , and this is achieved with the counter of a 16-bit register (TMRx\_DIV). Its value can be changed on the fly since the TMRx\_DIV control register is buffered. The new prescaler ratio takes effect at the next update event.

Figure 10-2 and Figure 10-3 give examples of on-the-fly prescaler ratio change.

Figure 10-2 Counter Timing Diagram with Prescaler Division Changing from 1 to 2



Figure 10-3 Counter Timing Diagram with Prescaler Division Changing from 1  $\sim$  4





#### 10.1.3.3 Counting Mode

The counter counts from 0 to the auto-reload value (TMRx\_AR register), and restarts from 0 and generates a counter overflow event.

An update event can be generated at each counter overflow; setting the UEVG bit in the TMRx\_EVEG register (by software or by using the slave mode controller) also generates the update events.

UEV events can be disabled by setting the UEVDIS bit in the TMRx\_CTRL1 register. This avoids changing the shadow registers while writing to the preload registers. No update event occurs until the UEVDIS bit is cleared. However, the counter and the prescaler still restart counting from 0 (but the prescaler ratio does not change). In addition, if the UEVRS (update request selection) bit in the TMRx\_CTRL1 register is set, setting the UEVG bit generates an update event UEV, but the UEVIF flag is not set (that is, no interrupt or DMA request is sent).

When an update event occurs, all the registers are updated (according to the UEVRS bit), and the update flag is set (the UEVIF bit in the TMRx\_STS register):

• The buffer of the prescaler is reloaded with the preload value (contents of the TMRx\_DIV register).

 $\bullet$  The auto-reload shadow register is updated with the preload value (TMRx\_AR). Figure 10-4  $\sim$ 



Hangzhou Vango Technologies, Inc.

Figure 10-9 show examples of the counter behavior at different clock frequencies when  $TMRx_AR = 0x36$ .



Figure 10-4 Counter Timing Diagram with Internal Clock Divided by 1

Figure 10-5 Counter Timing Diagram with Internal Clock Divided by 2



Figure 10-6 Counter Timing Diagram with Internal Clock Divided by 4



| CK_INT                           |      |      |      |        |
|----------------------------------|------|------|------|--------|
| CNT_EN                           |      |      |      |        |
| Timer clock = CK_CNT             |      |      | Π    |        |
| Counter register                 | 0035 | 0036 | 0000 | X 0001 |
| Counter overflow                 |      |      | Π    |        |
| Update event<br>(UEV)            |      |      |      |        |
| Update interrupt flag<br>(UEVIF) |      |      |      |        |

Figure 10-7 Counter Timing Diagram with Internal Clock Divided by N



Figure 10-8 Counter Timing Diagram with Update Event When ARPEN = 0 (TMRx\_AR Not Preloaded)





Figure 10-9 Counter Timing Diagram with Update Event When ARPEN = 1 (TMRx\_AR is Preloaded)



#### 10.1.3.4 Clock Source

The counter clock is provided by the internal clock (CK\_INT) source.

The CNTEN bit in the TMRx\_CTRL1 register and the UEVG bit in the TMRx\_EVEG register are the actual



control bits, which can be changed only by software (except for the UEVG bit, which is cleared automatically). Once the CNTEN bit is written '1', the prescaler is clocked by the internal clock.

Figure 10-10 shows the behavior of the control circuit and the up counter in normal mode without prescaler.



Figure 10-10 Normal Mode Timing Diagram with Internal Clock Divided by 1

#### 10.1.3.5 Debug Mode

When the microcontroller enters debug mode (Cortex<sup>®</sup>-M4F core halted), the TMRx counter either continues to work or stops, depending on the configuration bit, DBG\_TMRx\_STOP, in the DBG module. For more details, please refer to <u>Section 20.2.2</u>.

# 10.1.4 TMR6 and TMR7 Registers

## 10.1.4.1 TMR6 and TMR7 Control Register 1 (TMRx\_CTRL1)

Address offset: 0x00

| Bit      | Name  | Туре     | Description                          |  |  |  |
|----------|-------|----------|--------------------------------------|--|--|--|
| Bit 15:8 | -     | -        | Reserved. Always read as 0.          |  |  |  |
| Bit 7    |       | ARPEN rw | Auto-reload preload enable           |  |  |  |
|          | AREIN | rw       | 0: TMRx_AR register is not buffered. |  |  |  |



|         |        |    | 1: TMRx_AR register is buffered.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|--------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 6:4 | -      | -  | Reserved. Always read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 3   | OPMODE | rw | One-pulse mode<br>0: The counter is not stopped at update event.<br>1: The counter stops counting at the next update event (clearing<br>the CNTEN bit).                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 2   | UEVRS  | rw | Update request source<br>This bit is set and cleared by software to select the UEV event<br>sources.<br>0: If interrupt/DMA is enabled, any of the following events<br>generates an update interrupt or DMA request:<br>- Counter overflow<br>- Setting the UEVG bit<br>- Updates generated from the slave mode controller<br>1: If interrupt/DMA is enabled, only counter overflow/underflow<br>generates an update interrupt or DMA request.                                                                                                                                                                       |
| Bit 1   | UEVDIS | rw | Update disable<br>This bit is set and cleared by software to enable or disable UEV<br>event generation.<br>0: UEV is enabled. An update event (UEV) is generated by one of<br>the following events:<br>- Counter overflow<br>- Setting the UEVG bit<br>- Updates generated from the slave mode controller<br>After update events are generated, buffered registers are loaded<br>with their preload values.<br>1: UEV is disabled. An update event is not generated, and the<br>shadow registers keep their values (AR, DIV). However, the<br>counter and the prescaler are reinitialized if the UEVG bit is set, or |
| Bit 0   | CNTEN  | rw | a hardware reset is received from the slave mode controller.<br>Counter enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         |        |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



|  | 0: Counter is disabled.                                          |
|--|------------------------------------------------------------------|
|  | 1: Counter is enabled.                                           |
|  | Note: Gated mode can work only if the CNTEN bit is set by        |
|  | software. In trigger mode, the CNTEN bit is automatically set by |
|  | hardware. In one-pulse mode, the CNTEN bit is cleared            |
|  | automatically when an update event occurs.                       |

# 10.1.4.2 TMR6 and TMR7 Control Register 2 (TMRx\_CTRL2)

Address offset: 0x04

| Bit      | Name  | Туре | Description                                                          |
|----------|-------|------|----------------------------------------------------------------------|
| Bit 15:7 | -     | -    | Reserved. Always read as 0.                                          |
|          |       |      | Master mode selection                                                |
|          |       |      | These bits are used to select the information in master mode to be   |
|          |       |      | sent to slave timers for synchronization (TRGO). The combinations    |
|          |       |      | are as follows:                                                      |
|          |       |      | 000: Reset - The UEVG bit in the TMRx_EVEG register is used as a     |
|          |       |      | trigger output (TRGO). If reset is generated by the trigger input    |
|          |       |      | (slave mode controller is configured as reset mode), then the        |
|          |       |      | signal on TRGO is delayed compared to the actual reset.              |
|          |       |      | 001: Enable - The counter enable signal, CNT_EN, is used as a        |
| Bit 6:4  | MMSEL | rw   | trigger output (TRGO). It can start several timers at the same time  |
|          |       |      | or control the time to enable a slave timer. The counter enable      |
|          |       |      | signal is generated by a logic OR between the CNTEN control bit      |
|          |       |      | and the trigger input when configured as gated mode. When the        |
|          |       |      | counter enable signal is controlled by the trigger input, there is a |
|          |       |      | delay on TRGO, unlessthe master/slave mode is selected (see the      |
|          |       |      | MSMODE bit in the TMRx_SMC register).                                |
|          |       |      | 010: Update - The update event is used as a trigger output           |
|          |       |      | (TRGO). For instance, a master timer can be used as a prescaler      |
|          |       |      | for a slave timer.                                                   |



Bit 3:0

Reserved. Always read as 0.

# 10.1.4.3 TMR6 and TMR7 DMA/Interrupt Enable Register (TMRx\_DIE)

Address offset: 0x0C

-

Reset value: 0x0000

| Bit      | Name  | Туре | Description                        |  |
|----------|-------|------|------------------------------------|--|
| Bit 15:9 | -     | -    | Reserved. Always read as 0.        |  |
| Bit 8    | UEVDE | rw   | Update DMA request enable          |  |
|          |       |      | 0: Update DMA request is disabled. |  |
|          |       |      | 1: Update DMA request is enabled.  |  |
| Bit 7:1  | -     | -    | Reserved. Always read as 0.        |  |
| Bit 0    | UEVIE | rw   | Update interrupt enable            |  |
|          |       |      | 0: Update interrupt is disable.    |  |
|          |       |      | 1: Update interrupt is enabled.    |  |

# 10.1.4.4 TMR6 and TMR7 Status Register (TMRx\_STS)

Address offset: 0x10

| Bit      | Name  | Туре | Description                                                      |  |
|----------|-------|------|------------------------------------------------------------------|--|
| Bit 15:1 | -     | -    | Reserved. Always read as 0.                                      |  |
| Bit 0    | UEVIF | rw   | Update interrupt flag                                            |  |
|          |       |      | This bit is set by hardware at an update event. It is cleared by |  |
|          |       |      | software.                                                        |  |
|          |       |      | 0: No update occurs.                                             |  |
|          |       |      | 1: Update interrupt occurs. This bit is set by hardware when:    |  |
|          |       |      | - A counter overflow occurs, and UEVDIS = 0 in the               |  |
|          |       |      | TMRx_CTRL1 register.                                             |  |



|  | <ul> <li>UEVRS = 0 and UEVDIS = 0 in the TMRx_CTRL1 register, and</li> </ul> |
|--|------------------------------------------------------------------------------|
|  | the reset bit, UEVG (TMRx_EVEG), reinitializes the counter.                  |
|  |                                                                              |

# 10.1.4.5 TMR6 and TMR7 Event Generation Register (TMRx\_EVEG)

Address offset: 0x14

Reset value: 0x0000

| Bit      | Name | Туре | Description                                                      |  |
|----------|------|------|------------------------------------------------------------------|--|
| Bit 15:1 | -    | -    | Reserved. Always read as 0.                                      |  |
| Bit 0    | UEVG | rw   | Update generation                                                |  |
|          |      |      | This bit is set by software and is automatically cleared by      |  |
|          |      |      | hardware.                                                        |  |
|          |      |      | 0: No effect                                                     |  |
|          |      |      | 1: Re-initialize the timer counter and generate an update to the |  |
|          |      |      | registers                                                        |  |
|          |      |      | Note: The prescaler is also cleared (but the prescaler ratio     |  |
|          |      |      | remains the same).                                               |  |

# 10.1.4.6 TMR6 and TMR7 Counter (TMRx\_CNT)

Address offset: 0x24

Reset value: 0x0000

| Bit      | Name      | Туре | Description   |
|----------|-----------|------|---------------|
| Bit 15:0 | CNT[15:0] | rw   | Counter value |

## 10.1.4.7 TMR6 and TMR7 Prescaler (TMRx\_DIV)

Address offset: 0x28



| Bit      | Name      | Туре | Description                                                                                                                                                                      |  |
|----------|-----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 15:0 | DIV[15:0] | rw   | Prescaler value<br>The counter clock frequency CK_CNT equals<br>f <sub>CK_DIV</sub> /(DIV[15:0]+1). At each update event, DIV value is sent to<br>the actual prescaler register. |  |

# 10.1.4.8 TMR6 and TMR7 Auto-reload Register (TMRx\_AR)

Address offset: 0x2C

Reset value: 0x0000

| Bit      | Name     | Туре | Description                                                                                                                                                                                                                    |
|----------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | AR[15:0] | rw   | Auto-reload value<br>AR value will be sent to the actual auto-reload register.<br>Please refer to <u>Section 10.1.3.1</u> for more details about AR update<br>and behavior. The counter stops when the auto-reload value is 0. |

# 10.2 General-purpose Timer (TMR2 to TMR5)

# **10.2.1 TMRx Introduction**

The general-purpose timers consist of a 16-bit auto-reload counter driven by a programmable prescaler.

They may be used for a variety of purposes, including measuring the pulse lengths of input signals (input capture) or generating output waveforms (output compare and PWM).

Pulse lengths and waveform periods can be modulated from a few microseconds to several milliseconds using the timer prescaler and the RCC clock controller prescalers.

The timers are completely independent, and they do not share any resources and can be synchronized. Please refer to <u>Section 10.2.3.15</u>.

# 10.2.2 TMRx Main Function

The main functions of general-purpose TMRx (TMR2, TMR3, TMR4, and TMR5) include:



• 16-bit up, down, and up/down auto-reload counter

*Note: 32-bit counter can be selected in TMR2 and TMR5. Please refer to <u>Section 10.2.4.1</u> TMRx\_CTRL1 <i>register for more details.* 

• 16-bit programmable prescaler (can be modified on the fly) used to divide the counter clock frequency by any factor between  $1 \sim 65536$ 

- 4 independent channels for:
  - Input capture
  - Output compare
  - PWM generation (Edge-aligned or Center-aligned modes)
  - One-pulse mode output
- Timers and the interconnected synchronization circuit are controlled by external signals.
- Interrupt/DMA is generated at the following events:

Update: Counter overflow/underflow, counter initialization (by software or internal/external trigger)

- Trigger event (counter starts, stops, initialized, or counts by internal/external trigger)
- Input capture
- Output compare
- Support incremental (quadrature) encoder and hall-sensor circuitry for positioning purposes
- Trigger input for external clock or cycle-by-cycle current management

Figure 10-11 General-purpose Timer Block Diagram





Event
 Interrupt and DMA output

### **10.2.3 TMRx Function Overview**

#### 10.2.3.1 Time-base Unit

This programmable timer mainly consists of a 16-bit counter and relevant auto-reload registers. The counter can count up, down, or both up and down. The counter clock is obtained through a prescaler.

The counter, the auto-reload register, and the prescaler register can be written or read by software. This is true even when the counter is running.

The time-base unit includes:

- Counter register (TMRx\_CNT)
- Prescaler register (TMRx\_DIV)
- Auto-reload register (TMRx\_AR)

The auto-reload register is preloaded. Each read or write to the auto-reload register will access the preload register. The contents written to the preload register are transferred into its shadow register immediately or at each update event (UEV) according to the auto-reload preload enable bit (ARPEN) in the TMRx\_CTRL1 register. When the UEVDIS bit in the TMRx\_CTRL1 register is '0', update events will be



generated once the counter reaches the overflow value (or underflow when downcounting). Update events can also be generated by software. Please refer to the following sections for the detailed introduction on generation of the update events.

The counter is driven by the prescaler clock output CK\_CNT, and it is enabled when the counterenable bit (CNTEN) in the TMRx\_CTRL1 register is set. (Please refer to the controller slave mode descriptions for more details on counter enable.)

*Note: The actual counter enable signal, CNT\_EN, is set 1 clock cycle after CNTEN is set.* 

#### Prescaler

The prescaler can divide the counter clock frequency by any factor between  $1 \sim 65536$ , and this is achieved with a 16-bit counter controlled by a 16-bit register (in the TMRx\_DIV register). Its value can be changed on the fly since the control register is buffered. The new prescaler ratio takes effect at the next update event.

Figure 10-12 and Figure 10-13 are examples of on-the-fly prescaler ratio change.



Figure 10-12 Counter Timing Diagram with Prescaler Division Changing from 1 to 2

Figure 10-13 Counter Timing Diagram with Prescaler Division Changing from 1  $\sim$  4





#### 10.2.3.2 Counter Mode

#### Upcounting mode

In upcounting mode, the counter counts from 0 to the auto-reload value (content of the TMRx\_AR counter), restarts from 0, and generates a counter overflow event.

An update event can be generated at each counter overflow; setting the UEVG bit in the TMRx\_EVEG register (by software or by using the slave mode controller) also generates the update events.

Update events can be disabled by setting the UEVDIS bit in the TMRx\_CTRL1 register. This avoids changing the shadow registers while writing new values to the preload registers. No update event occurs until the UEVDIS bit is cleared. However, when the update events are generated, the counter and the prescaler are still cleared (but the prescaler ratio does not change). In addition, if the UEVRS (update request selection) bit in the TMRx\_CTRL1 register is set, setting the UEVG bit generates an update event UEV, but the UEVIF flag is not set by hardware (that is, no interrupt or DMA request is sent). This can avoid update and capture interrupt generation when the counter is cleared in capture mode.

When an update event occurs, all the registers are updated, and the update flag (the UEVIF bit in the TMRx\_STS register) is set by hardware (according to the UEVRS bit).

- The buffer of the prescaler is reloaded with the preload value (content of the TMRx\_DIV register).
- The auto-reload shadow register is updated with the preload value (TMRx\_AR).



Figure 10-14 ~ Figure 10-19 show the examples of the counter behavior for different clock frequencies when TMRx\_AR = 0x36:

Figure 10-14 Counter Timing Diagram with Internal Clock Divided by 1

Figure 10-15 Counter Timing Diagram with Internal Clock Divided by 2



Figure 10-16 Counter Timing Diagram with Internal Clock Divided by 4



| CK_INT                             |      |      |       |        |
|------------------------------------|------|------|-------|--------|
| CNT_EN —                           |      |      |       |        |
| Timer clock = CK_CNT —             |      | Π    |       |        |
| Counter register                   | 0035 | 0036 | x0000 | X 0001 |
| Counter overflow —                 |      |      |       |        |
| Update event<br>(UEV)              |      |      | Π     |        |
| Update interrupt flag<br>(UEVIF) — |      |      |       |        |

Figure 10-17 Counter Timing Diagram with Internal Clock Divided by N



Figure 10-18 Counter Timing Diagram with Update Event When ARPEN = 0 (TMRx\_AR Not Preloaded)





Writing new values to the TMRx\_AR register

Figure 10-19 Counter Timing Diagram with Update Event When ARPEN = 1 (TMRx\_AR is Preloaded)





#### **Downcounting mode**

In downcounting mode, the counter counts from the auto-reload value (content of the TMRx\_AR counter) down to 0, and restarts from the auto-reload value and generates a counter underflow event.

An update event can be generated at each counter underflow; setting the UEVG bit in the TMRx\_EVEG register (by software or by using the slave mode controller) also generates an update event.



Update events can be disabled by setting the UEVDIS bit in the TMRx\_CTRL1 register. This avoids changing the shadow registers while writing new values to the preload registers. Thus, no update event occurs until the UEVDIS bit is cleared. However, the counter still counts from the current auto-reload value, and the prescaler counter restarts from 0 (but the prescaler ratio does not change). In addition, if the UEVRS (update request selection) bit in the TMRx\_CTRL1 register is set, setting the UEVG bit generates an update event UEV, but the UEVIF flag is not set (so no interrupt or DMA request is generated). This can avoid update and capture interrupts generation when a capture event occurs and the counter is cleared.

When an update event occurs, all the registers are updated and the update flag bit (the UEVIF bit in the TMRx\_STS register) is set (according to the UEVRS bit).

• The buffer of the prescaler is reloaded with the preload value (content of the TMRx\_DIV register).

• The current auto-reload register is updated with the preload value (content of the TMRx\_AR register).

Note: Auto-reload is updated before the counter is reloaded, so the next cycle will be the expected value.

Figure 10-20 ~ Figure 10-24 show the examples of the counter behavior for different clock frequencies when TMRx\_AR = 0x36:



Figure 10-20 Counter Timing Diagram with Internal Clock Divided by 1

Figure 10-21 Counter Timing Diagram with Internal Clock Divided by 2



| CK_INT                           |                    |                     |
|----------------------------------|--------------------|---------------------|
| CNT_EN                           |                    |                     |
| Timer clock = CK_CNT             |                    |                     |
| Counter register                 | 0002 X 0001 X 0000 | 0036 0035 0034 0033 |
| Counter overflow                 |                    |                     |
| Update event<br>(UEV)            |                    | ┌─────              |
| Update interrupt flag<br>(UEVIF) |                    |                     |

Figure 10-22 Counter Timing Diagram with Internal Clock Divided by 4

| CK_INT                         |      |      |      |        |
|--------------------------------|------|------|------|--------|
| CNT_EN                         |      |      |      |        |
| Timer clock = CK_CNT           |      | ∏    |      |        |
| Counter register               | 0001 | 0000 | 0036 | X 0035 |
| Counter overflow               |      |      |      |        |
| Update event<br>(UEV)          |      |      |      |        |
| Update interrupt fl<br>(UEVIF) | ag   |      |      |        |

Figure 10-23 Counter Timing Diagram with Internal Clock Divided by N





Figure 10-24 Counter Timing Diagram with Update Event When ARPEN = 0



Writing new values to the TMRx\_AR register

#### Center-aligned mode (Up/Down counting)

In center-aligned mode, the counter counts from 0 to the auto-reload value (content of the TMRx\_AR register) – 1, generates a counter overflow event, and counts from the auto-reload value down to 1 and generates a counter underflow event. Then, it restarts counting from 0.

In this mode, the DIR direction bit in the TMRx\_CTRL1 register cannot be written. It is updated by hardware and indicates the current counting direction.



The update event can be generated at each counter overflow and at each counter underflow, or by setting the UEVG bit in the TMRx\_EVEG register (by software or by using the slave mode controller). Afterwards, the counter as well as the prescaler restarts counting from 0.

The UEV update event can be disabled by setting the UEVDIS bit in the TMRx\_CTRL1 register. This can avoid updating the shadow registers while writing new values to the preload registers. Therefore, no update event occurs until the UEVDIS bit is cleared. However, the counter continues counting up or down based on the current auto-reload value. In addition, if the UEVRS bit (update request selection) in the TMRx\_CTRL1 register is set, setting the UEVG bit generates an update event UEV without setting the UEVIF flag (so no interrupt or DMA request is generated). This can avoid generating both update and capture interrupts when the capture event occurs and the counter is cleared.

When an update event occurs, all the registers are updated, and the update flag bit (the UEVIF bit in the TMRx\_STS register) is set (according to the UEVRS bit).

• The buffer of the prescaler is reloaded with the preload value (content of the TMRx\_DIV register).

• The current auto-reload register is updated with the preload value (content of the TMRx\_AR register).

Note: If an update is generated because of counter overflow, auto-reload is updated before the counter is reloaded, so the next cycle will be the expected value (the counter is reloaded with the new value).

Figure  $10-25 \sim$  Figure 10-30 show the examples of the counter behavior for different clock frequencies: Figure 10-25 Counter Timing Diagram with Internal Clock Divided by 1, TMRx\_AR = 0x6





Figure 10-26 Counter Timing Diagram with Internal Clock Divided by 2



Figure 10-27 Counter Timing Diagram with Internal Clock Divided by 4, TMRx\_AR = 0x36





Figure 10-28 Counter Timing Diagram with Internal Clock Divided by N



Figure 10-29 Counter Timing Diagram with Update Event When ARPEN = 1 (Counter underflow)



Figure 10-30 Counter Timing Diagram with Update Event When ARPEN = 1 (Counter overflow)



# 10.2.3.3 Clock Selection

The counter clock can be provided by the following clock source:



- Internal clock (CK\_INT)
- External clock mode 1: External input pin (TIx)
- External clock mode 2: External trigger input (ETR)

• Internal trigger input (ITRx): Use one timer as the prescaler for another timer. For example, the user can configure Timer 1 to act as the prescaler for Timer 2. Please refer to <u>Section 10.2.3.15</u>.

#### Internal clock source (CK\_INT)

If the slave mode controller is disabled (SMSEL = 000 in the TMRx\_SMC register), the CNTEN, DIR (in the TMRx\_CTRL1 register) and UEVG bits (in the TMRx\_EVEG register) are the actual control bits, and they can be changed only by software (except for the UEVG bit, which will be cleared automatically). As soon as the CNTEN bit is written '1', the prescaler is clocked by the internal clock CK\_INT.

Figure 10-31 shows the behavior of the control circuit and the up counter in normal mode, without prescaler.





#### External clock mode 1

This mode is selected when SMSEL = 111 in the TMRx\_SMC register. The counter can count at each rising or falling edge on a selected input.

Figure 10-32 TI2 External Clock Connection Example





For example, to configure the up counter to count in response to a rising edge on the TI2 input, use the following procedure:

1. Configure channel 2 to detect the rising edges on the TI2 input by writing C2SEL = 01' in the TMRx\_CCM1 register.

2. Configure the input filter duration by writing the IC2DF[3:0] bits in the TMRx\_CCM1 register (if no filter is needed, keep IC2DF = 0000).

Note: The capture prescaler is not used as trigger, so it does not need to be configured.

3. Select the rising edge polarity by writing C2P = 0' in the TMRx\_CCE register.

4. Select the timer external clock mode 1 by writing SMSEL = `111' in the TMRx\_SMC register.

5. Select TI2 as the trigger input source by writing TRGSEL = `110' in the TMRx\_SMC register.

6. Enable the counter by writing CNTEN = 1' in the TMRx\_CTRL1 register.

When a rising edge occurs on TI2, the counter counts once, and the TRGIF flag is set.

The delay between the rising edge on TI2 and the actual clock of the counter depends on the resynchronization circuit on TI2 input.

Figure 10-33 Control Circuit in External Clock Mode 1





#### **External clock mode 2**

This mode is selected by writing ECLKEN = 1 in the TMRx\_SMC register.

The counter can count at each rising or falling edge on the external trigger ETR. Figure 10-34 shows the block diagram of the external trigger input.

Figure 10-34 Block Diagram of External Trigger Input



For example, to configure the up counter to count each 2 rising edges on ETR, use the following procedure:

1. Since no filter is needed in this example, write ETDF[3:0] = 0000 in the TMRx\_SMC register.

2. Set the prescaler by writing ETD[1:0] = 01 in the TMRx\_SMC register.

- 3. Select the rising edge detection on ETR by writing ETRGP = 0 in the TMRx\_SMC register.
- 4. Enable the external clock mode 2 by writing ECLKEN = 1 in the TMRx\_SMC register.

5. Enable the counter by writing CNTEN = 1 in the TMRx\_CTRL1 register. The counter counts once each



2 ETR rising edges.

The delay between the rising edge on ETR and the actual clock of the counter depends on the resynchronization circuit on the ETRP signal.

Figure 10-35 Control Circuit in External Clock Mode 2



#### 10.2.3.4 Capture/Compare Channel

Each capture/compare channel is built around a capture/compare register (including a shadow register), also an input stage for capture (digital filter, multiplexing, and prescaler) and an output stage (comparator and output control). Figure 10-36 ~ Figure 10-38 provide an overview of one capture/compare channel.

The input stage samples the corresponding TIx input signal to generate a filtered signal TIxF. Then, an edge detector with polarity selection generates a signal (TIxFPx) which can be the trigger input for the slave mode controller, or be the capture command. This signal enters the capture register through the prescaler.

Figure 10-36 Capture/Compare Channel (e.g. Channel 1 Input Stage)





The output stage generates an intermediate waveform OCxRef (active high) which serves as reference. The polarity of final output signal is determined by the end of the chain.





Figure 10-38 Capture/Compare Channel Output Stage (Channel 1)



The capture/compare block is made of one preload register and one shadow register. Write and read only access the preload register.

In capture mode, captures are actually done in the shadow register, and then copied into the preload register.

In compare mode, the content of the preload register is copied into the shadow register, and then the content of the shadow register is compared with the counter.

#### 10.2.3.5 Input Capture Mode

In input capture mode, the capture/compare registers (TMRx\_CCx) latch the current counter value after a corresponding edge on the ICx signal is detected. When a capture occurs, the corresponding CxIF flag (the TMRx\_STS register) is set. An interrupt or a DMA request can be sent if enabled. If a capture occurs when the CxIF flag is already high, the over-capture flag CxOF (the TMRx\_STS register) is set. CxIF can be cleared by writing CxIF = 0 or by reading the captured data stored in the TMRx\_CCx register. CxOF = 0 is cleared when writing CxOF = 0.

The following example shows how to capture the counter value to the TMRx\_CC1 register during TI1 input rising edge:

• Select the active input: Write C1SEL = 01 in the TMRx\_CC1 register since the TMRx\_CC1 register must be linked to the TI1 input. The channel is configured as input as long as the C1SEL is not '00'. The TM1\_CC1 register becomes read-only.

• Program the desired input filter duration according to the input signal (if the input is TIx, the control bit of the input filter is the ICxDF bit in the TMRx\_CCMx register). If the input signal is not stable during five internal clock cycles at most, the filter duration should be configured longer



than five clock cycles. Therefore, an actual edged transition on TI1 can be validated by 8 consecutive samples (at fCK\_INT frequency). That is, write IC1DF = 0011 in the TMRx\_CCM1 register.

• Select the active transition edge on the TI1 channel by writing C1P = 0 (rising edge) in the TMRx\_CCE register).

• Program the input prescaler. In this example, each valid transition is expected to be captured, so the prescaler is disabled (write IC1DIV = 00 in the TMRx\_CCM1 register).

• Set C1EN = 1 in the TMRx\_CCE register to allow the counter value to be captured into the capture register

• If needed, enable the relevant interrupt request by setting the C1IE bit in the TMRx\_DIE register, and the DMA request by setting the C1DE bit in the TMRx\_DIE register.

When an input capture occurs:

• The counter value is sent to the TMRx\_CC1 register on active transition.

• C1IF flag is set (interrupt flag). When at least two consecutive captures occur and the C1IF flag is not cleared, C1OF is also set.

• An interrupt is generated if the C1IE bit is set.

• A DMA request is generated if the C1DE bit is set.

In case of overcapture, it is recommended that the data be read before the overcapture flag. This is to avoid missing an overcapture information that is generated after reading the overcapture flag and before reading the data.

*Note: Input capture interrupt and/or DMA requests can be generated by setting the corresponding CxG bit in the TMRx\_EVEG register with software.* 

#### 10.2.3.6 PWM Input Mode

This mode is a special case of input capture mode. The procedure is the same as input capture mode except for the following conditions:

- Two ICx signals are mapped on the same TIx input.
- The two ICx signals are active on edges but with opposite polarities.

• One of the two TIxFP signals is used as trigger input signal and the slave mode controller is configured as reset mode.



For example, if users need to measure the period (the TMRx\_CC1 register) and the duty cycle (the TMRx\_CC2 register) of the PWM signal input on TI1, the procedure is as follows (depending on CK\_INT frequency and prescaler value):

• Select the active input for TMRx\_CC1: Write C1SEL = 01 in the TMRx\_CCM1 register (TI1 selected).

• Select the active polarity for TI1FP1 (used to capture data into TMRx\_CC1 and clear the counter): Write C1P = 0 (active on rising edge).

• Select the active input for TMRx\_CC2: Write C2SEL = 10 in the TMRx\_CCM1 register (TI1 selected).

• Select the active polarity for TI1FP2 (capture data to TMRx\_CC2): Write C2P = 1 (active on falling edge).

• Select the valid trigger input signal: Write TRGSEL = 101 in the TMRx\_SMC register (TI1FP1 selected).

• Configure the slave mode controller as reset mode: Write SMSEL = 100 in the TMRx\_SMC register.

• Enable the captures: Write C1EN = 1 and C2EN = 1 in the TMRx\_CCE register.

Figure 10-39 PWM Input Mode Timing



Since only TI1FP1 and TI2FP2 are connected to the slave mode controller, the PWM input mode can be



Hangzhou Vango Technologies, Inc.

used only with the TMRx\_CH1/TMRx\_CH2 signals.

### 10.2.3.7 Forced Output Mode

In output mode (CxSEL = 00 in the TMRx\_CCMx register), output compare signal (OCxREF and the corresponding OCx) can be forced to be active or inactive level directly by software, independent of any comparison between the output compare register and the counter.

To force an output compare signal (OCxREF/OCx) to its active level, users can write the corresponding OCxMODE = 101 in the TMRx\_CCMx register. In this way, OCxREF is forced high (OCxREF is always active high), and at the same time OCx gets the opposite value of the CxP polarity bit.

For example: CxP = 0 (OCx active high), then OCx is forced to be high level.

The OCxREF signal can be forced low by writing OCxMODE = 100 in the TMRx\_CCx register.

In this mode, the comparison between the TMRx\_CCx shadow register and the counter is still ongoing, and the corresponding flag is also modified. Accordingly, the corresponding interrupt and DMA requests are still generated. This will be described in the "Output Compare Mode" section.

### 10.2.3.8 Output Compare Mode

This function is used to control an output waveform or to indicate that a period of time has elapsed.

When a match is found between the capture/compare register and the counter, the output compare function proceeds as follows:

• Output the value defined by the output compare mode (the OCxMODE bit in the TMRx\_CCMx register) and the output polarity (the CxP bit in the TMRx\_CCE register) to the corresponding pin. When being compared and matched, the output pin can keep its level (OCxMODE = 000), be set active (OCxMODE = 001), be set inactive (OCxMODE = 010), or toggle (OCxMODE = 011).

• Set the flag bit in the interrupt status register ( the CxIF bit in the TMRx\_STS register).

• An interrupt will be generated if the corresponding interrupt mask is set (the CxI E bit in the TMRx\_DIE register).

• A DMA request will be generated if the corresponding enable bit is set (the CxDE bit in the TMRx\_DIE register, the CDSEL bit in the TMRx\_CTRL2 register for the DMA request selection).

The OCxPEN bit in the TMRx\_CCMx register can be configured to choose whether the TMRx\_CCx register uses the preload register.



In output compare mode, the update event UEV has no effect on OCxREF and OCx output.

The timing resolution can reach one count of the counter. Output compare mode can also be used to output a single pulse (in one-pulse mode).

Output compare mode configuration procedure is as follows:

1. Select the counter clock (internal, external, and prescaler).

2. Write the corresponding data to the TMRx\_AR and the TMRx\_CCx registers.

3. Set the CxIE and/or CxDE bits if an interrupt and/or DMA request is to be generated.

4. Select the output mode. For example, when the counter CNT and the CCx bit are matched, toggle the output pin of OCx, CCx preload is not disabled, and the OCx output is enabled with active high, users must configure OCxMODE = '011', OCxPEN = '0', CxP = '0', and CxEN = '1'.

5. Enable the counter by setting the CNTEN bit in the TMRx\_CTRL1 register.

The TMRx\_CCx register can be updated at any time by software to control the output waveform, under the condition that the preload register is not enabled (OCxPEN = 0', else the TMRx\_CCx shadow register can only be updated at the next update event). An example is shown in Figure 10-40.

Figure 10-40 Output Compare Mode, Toggle on OC1



### 10.2.3.9 PWM Mode

Match detected on CC1 Interrupt generated if enabled Pulse width modulation mode can generate a

signal with its frequency determined by the TMRx\_AR register and its duty cycle determined by



TMRx\_CCx register.

Writing '110' (PWM mode 1) or '111' (PWM mode 2) in the OCxMODE bit in the TMRx\_CCMx register can independently configure each OCx output channel and generate single-channel PWM. The OCxPEN bit in the TMRx\_CCMx register must be configured to enable the corresponding preload register. Finally, the ARPEN bit in the TMRx\_CTRL1 register (in upcounting or center-aligned modes) must be set to enable the auto-reload preload register.

Since the preload registers are transferred to the shadow registers only when an update event occurs, before starting the counter, users must initialize all the registers by setting the UEVG bit in the TMRx\_EVEG register. OCx polarity is software programmable by setting the CxP bit in the TMRx\_CCE register. It can be programmed as active high or active low. OCx output enable is controlled by the CxEN bit in the TMRx\_CCE register. Please refer to the description of the TMRx\_CCE Register for more details.

In PWM mode (1 or 2), TMRx\_CNT and TMRx\_CCx are always compared (according to the direction of the counter) to confirm that TMRx\_CCx  $\leq$  TMRx\_CNT or TMRx\_CNT  $\leq$  TMRx\_CCx. However, to ensure the consistency with OCREF\_CLR function (before the next PWM cycle, OCxREF can be cleared by an external event on the ETR signal), OCxREF is generated only when:

• The result of comparison changes.

• The output compare mode (the OCxMODE bit in the TMRx\_CCMx register) is switched from "frozen" (No comparison, OCxMODE = '000') to a certain PWM mode (OCxMODE = '110' or '111').

In this way, software can force PWM output while running.

The timer can generate the edge-aligned or center-aligned PWM signal according to the status of CMSEL bit in the TMRx\_CTRL1 register.

#### PWM edge-aligned mode Upcounting configuration

Upcounting is active when the DIR bit in the TMRx\_CTRL1 register is low. Please refer to <u>Section 10.2.3.2.</u> The following is an example of PWM mode 1. The reference PWM signal, OCxREF, is high once TMRx\_CNT < TMRx\_CCx; else, it becomes low. If the compare value in TMRx\_CCx is greater than the auto-reload value (in TMRx\_AR), OCxREF is held at `1'.

If the compare value is 0, then OCxREF is held at '0'. Figure 10-41 shows an example of edge-aligned PWM waveforms with TMRx\_AR = 8.

Figure 10-41 Edge-aligned PWM Waveforms (AR = 8)



Hangzhou Vango Technologies, Inc.



#### **Downcounting configuration**

Downcounting is active when the DIR bit in the TMRx\_CTRL1 register is high. Please refer to Section

<u>10.2.3.2.</u> In PWM mode 1, the reference signal, OCxREF, is low once MRx\_CNT > TMRx\_CCx; else, it becomes high. If the compare value in TMRx\_CCx is greater than the auto-reload value in TMRx\_AR, then OCxREF is held at '1'. 0% PWM is not possible in this mode.

#### **PWM** center-aligned mode

Center-aligned mode is active when the CMSEL bit in the TMRx\_CTRL1 register is not '00' (all the other configurations have the same effect on the OCxREF/OCx signals). According to different CMSEL bit configurations, the compare flag is set when the counter counts up, counts down, or both counts up and down. The direction bit (DIR) in the TMRx\_CTRL1 register is updated by hardware and must not be changed by software. Please refer to the center-aligned mode in <u>Section 10.2.3.2</u>.

Figure 10-42 shows several center-aligned PWM waveforms in an example where:

- TMRx\_AR = 8
- PWM mode 1

• The compare flag is set when the counter counts down, center -aligned mode 1 is selected, and CMSEL = 01 in the TMRx\_CTRL1 register.

Figure 10-42 Center-aligned PWM Waveforms (AP = 8)





#### Hints on using center-aligned mode:

• When entering the center-aligned mode, the current up/down configuration is used. This means whether the counter counts up or down depends on the current value of the DIR bit in the TMRx\_CTRL1 register. In addition, the DIR and CMSEL bits cannot be changed by software at the same time.

• In center-aligned mode, writing to the counter while running is not recommended as it may lead to unexpected results. In particular:

If the value written to the counter is greater than the auto-reload value (TMRx\_CNT > TMRx\_AR),
 the direction will not be updated. For example, if the counter is counting up, it will keep counting up.

The direction is updated if 0 or the TMRx\_AR value is written to the counter, but no update event
 UEV will be generated.

• The safest way to use the center-aligned mode is to generate an update by software (setting the UEVG bit in the TMRx\_EVEG register) before enabling the counter, and do not write the counter while it is running.



## 10.2.3.10 One-pulse Mode

One-pulse mode (OPM) is quite different from the above-mentioned modes. It allows the counter to respond to a stimulus and to generate a pulse with a programmable length after a programmable delay.

The counter can be enabled through the slave mode controller, generating waveforms in output compare mode or PWM mode. One-pulse mode is selected by setting the OPMODE bit in the TMRx\_CTRL1 register, and this can stop the counter automatically at the next update event UEV.

A pulse can be generated only if the compare value is different from the initial counter value. Before enabling (when the timer is waiting for the trigger), the following configuration must be done:

In upcounting:  $CNT < CCx \le AR$  (especially, 0 < CCx) In downcounting: CNT > CCx

Figure 10-43 Example of One-pulse Mode



For example, if users want to generate a positive pulse with a length of tPULSE on OC1 once a rising edge is detected on the TI2 input pin and after a delay  $t_{DELAY}$ .

If TI2FP2 is used as trigger 1:

• Map TI2FP2 to TI2 by writing C2SEL = '01' in the TMRx \_CCM1 register.

• Write C2P = '0' in the TMRx\_CCE register to enable TI2FP2 to detect a rising edge.

• Write TRGSEL = '110' in the TMRx\_SMC register to make TI2FP2 the trigger of the slave mode controller (TRGI).

• Write SMSEL = '110' in the TMRx\_SMC register (trigger mode), and TI2FP2 is used to enable the counter.

The OPM waveform is defined by the value written to the compare registers (the clock frequency and the



counter prescaler should be taken into account).

 $\bullet$  t<sub>DELAY</sub> is defined by the value written to the TMRx\_CC1 register.

•  $t_{PULSE}$  is defined by the comparison result of auto-reload value and the compare value (TMRx\_AR - TMRx\_CC1).

• Assume that users want to generate a waveform with a transition from '0' to '1' when a compare match occurs, and a transition from '1' to '0' when the counter reaches the preload value. First, set OC1MODE = '111' in the TMRx\_CCM1 register to enter PWM mode 2. Enable the desired preload registers by setting OC1PEN = '1' in the TMRx\_CCM1 register and the ARPEN bit in the TMRx\_CTRL1 register. Afterwards, write compare value in the TMRx\_CC1 register, write auto-reload value in the TMRx\_AR register, modify the UEVG bit to generate an update event, and wait for an external trigger event on TI2. In this example, C1P = '0'.

In this example, the DIR and CMSEL bits in the TMRx\_CTRL1 register should be low. Since only one pulse is needed, '1' must be written to the OPMODE bit in the TMRx\_CTRL1 register to stop the counter at the next update event (when the counter rolls over to 0 from the auto-reload value).

#### Special case: OCx fast enable

In one-pulse mode, the counter is enabled by setting the CNTEN bit on the edge detection logic of TIx input pin. Then, the comparison between the counter and the compare value makes output toggle. However, since several clock cycles are needed for these operations, it limits the minimum delay tDELAY users can get.

The OCxFEN bit in the TMRx\_CCMx register can be set to output a waveform with the minimum delay. In this case, OCxREF (and OCx) are forced to respond to the stimulus, instead of relying on the comparison result. The waveform outputted is the same as the one being compared and matched. OCxFEN acts only if the channel is configured as PWM1 or PWM2 mode.

### 10.2.3.11 Clearing OCxREF Signal on an External Event

For a given channel, a high level of the ETRF input can lower the OCxREF signal if the OCxDIS bit in the TMRx\_CCMx register is set. The OCxREF signal remains low until the next update event, UEV, occurs.

This function can only be used in output compare and PWM modes, and does not work in the forced output mode.

For example, the OCxREF signal can be connected to a comparator output for current control. In this



case, ETR must be configured as follows:

1. The external trigger prescaler should be kept OFF: ETD[1:0] = '00' in the TMRx\_SMC register.

2. The external clock mode 2 must be disabled: ECLKEN = '0' in the TMRx\_SMC register.

3. The external trigger polarity (ETRGP) and the external trigger filter (ETDF) can be configured according to users' needs.

Figure 10-44 shows how OCxREF signal behaves to respond to different OCxDIS values when the ETRF input becomes high. In this example, the timer TMRx is programmed in PWM mode.

Figure 10-44 Clearing OCxREF in TMRx



### 10.2.3.12 Encoder Interface Mode

To select the encoder interface mode, write SMSEL = 001 in the TMRx\_SMC register if the counter is counting on TI2 edges only; write SMSEL = 010 if it is counting on TI1 edges only; write SMSEL = 011 if it is counting on both TI1 and TI2 edges.

Select the TI1 and TI2 polarity by programming the C1P and C2P bits in the TMRx\_CCE register. Users can program the input filter as well when it is needed.

The two inputs, TI1 and TI2, are used as the interface of incremental encoder. Please refer to Table 10-1. If the counter is enabled (CNTEN = '1' in the TMRx\_CTRL1 register), it is clocked by each valid transition on TI1FP1 or TI2FP2. TI1FP1 and TI2FP2 are the signals of TI1 and TI2 after input filter and polarity selection. If not filtered and not inverted, TI1FP1 = TI1 and TI2FP2 = TI2. Count pulses and direction signal are generated according to the transition sequence of the two inputs. The counter counts up or



down according to the transition sequence of the two inputs, and at the same time the DIR bit in the TMRx\_CTRL1 register is set accordingly by hardware.

The DIR bit is re-calculated at each transition on any input (TI1 or TI2), no matter the counter is counting on TI1 only, TI2 only, or both TI1 and TI2.

Encoder interface mode basically acts like an external clock with direction selection. This means that the counter just counts continuously between 0 and the auto-reload value in the TMRx\_AR register (0 to AR or ARR down to 0, depending on the direction). Hence, the TMRx\_AR register must be configured before the counting starts. Likewise, features of the capture, comparator, prescaler, and trigger output work as usual.

In this mode, the counter is modified automatically according to the speed and the direction of the incremental encoder. Its content, therefore, always indicates the position of the encoder. The counting direction corresponds to the rotation direction of the connected sensor. Table 10-1 lists all the possible combinations, assuming that TI1 and TI2 do not switch at the same time.

|                         | Level on Opposite Signal TI1FP1 Signal |          | gnal     | TI2FP2 Signal |          |  |
|-------------------------|----------------------------------------|----------|----------|---------------|----------|--|
| Active Edge             | (TI1FP1 to TI2, TI2FP2 to TI1)         | Rising   | Falling  | Rising        | Falling  |  |
|                         | High                                   | Down     | Up       | No count      | No count |  |
| Counting on TI1 only    | Low                                    | Up       | Down     | No count      | No count |  |
|                         | High                                   | No count | No count | Up            | Down     |  |
| Counting on TI2 only    | Low                                    | No count | No count | Down          | Up       |  |
| Counting on TI1 and TI2 | High                                   | Down     | Up       | Up            | Down     |  |
| Counting on TI1 and TI2 | Low                                    | Up       | Down     | Down          | Up       |  |

Table 10-1 Counting Direction and Encoder Signals

An external incremental encoder can be connected directly to MCU without external interface logic. However, comparators are normally used to convert the encoder's differential outputs to digital signals. This greatly increases noise immunity. The third encoder output signal, which indicates the mechanical zero position, can be connected to an external interrupt input to trigger a counter reset.

Figure 10-45 gives an example of counter operation, showing counting signal generation and direction control. It also shows how input jitter is compensated when both edges are selected. Jitters might occur if the sensor is positioned near to one of the switching points. For example, assume that the configuration



is the following:

- C1SEL = '01' (TMRx\_CCM1 register, IC1FP1 is mapped on TI1.)
- C2SEL = '01' (TMRx\_CCM1 register, IC2FP2 is mapped on TI2.)
- C1P = '0' (TMRx\_CCE register, IC1FP1 not inverted, IC1FP1 = TI1)
- C2P = '0' (TMRx\_CCE register, IC2FP2 not inverted, IC2FP2 = TI2)
- SMSEL = '011' (TMRx\_SMC register, all inputs are active on both rising and falling edges.)
- CNTEN = '1' (TMRx\_CTRL1 register, counter enabled)

Figure 10-45 Example of Counter Operation in Encoder Interface Mode



Figure 10-46 is an example of counter behavior when IC1FP1 polarity is inverted (the same configuration as the above example, except for C1P = 1').

Figure 10-46 Example of Encoder Interface Mode with IC1FP1 Polarity Inverted





The timer, when configured as encoder interface mode, provides information on the sensor's current position. Using the second timer configured in capture mode can measure the interval period between two encoder events to obtain the dynamic information (speed, acceleration, and deceleration). The encoder output which indicates the mechanical zero can be used for this purpose. Based on the interval between two events, the counter can also be read regularly. If possible, users can latch the counter value into the third input capture register (the capture signal must be periodic and can be generated by another timer). It is also possible to read its value through a DMA request generated by a real-time clock.

### **10.2.3.13 Timer Input XOR Function**

The TI1SEL bit in the TMRx\_CTRL2 register allows the input filter of channel 1 to be connected to the output of an XOR gate, which includes three input pins, TMRx\_CH1, TMRx\_CH2, and TMRx\_CH3.

The XOR output can be used with all the timer input functions, such as trigger or input capture. An example of this feature used to interface Hall sensors is listed in Section 10.4.3.18.

### 10.2.3.14 Timer and External Trigger Synchronization

The TMRx timer can be synchronized with an external trigger in several modes: reset mode, gated mode, and trigger mode.

#### Slave mode: Reset mode

The counter and its prescaler can be reinitialized when a trigger input event occurs. In this case, if the UEVRS bit of the TMRx\_CTRL1 register is low, an update event UEV is generated. Then, all the preloaded registers (TMRx\_AR, TMRx\_CCx) will be updated.

In the following example, the up counter is cleared due to a rising edge on TI1 input:

• Configure channel 1 to detect the rising edges on TI1. Configure the input filter duration (in this example, no filter is needed, so keep IC1DF = 0000). The capture prescaler is not used for triggering, so it does not need to be configured. The C1SEL bit selects the input capture source only, that is, C1SEL = 01 in the TMRx\_CCM1 register. Write C1P = 0 in the TMRx\_CCE register to confirm the polarity (and detect rising edges only).

• Configure the timer as reset mode by writing SMSEL = 100 in the TMRx\_SMC register. Select TI1 as the input source by writing TRGSEL = 101 in the TMRx\_SMC register.

• Start the counter by writing CNTEN = 1 in the TMRx\_CTRL1 register.



The counter starts counting on the internal clock, and runs normally until TI1 rising edge occurs; at this time, the counter is cleared and restarts from 0. In the meantime, the trigger flag (the TRGIF bit in the TMRx\_STS register) is set, and an interrupt request, or a DMA request can be sent depending on the configuration of the TRGIE bit in the TMRx\_DIE register (interrupt enable) and the TRGDE bits in TMRx\_DIE register (DMA enable). Figure 10-47 shows the behavior when the auto-reload register TMRx\_AR = 0x36. The delay between the rising edge on TI1 and the actual reset of the counter is determined by the resynchronization circuit on TI1 input.

Figure 10-47 Control Circuit in Reset Mode



#### Slave mode: Gated mode

The counter can be enabled according to the selected level of input.

In the following example, the counter counts up only when TI1 input is low:

• Configure channel 1 to detect low levels on TI1. Configure the input filter duration (in this example, no filter is needed, so keep IC1DF = 0000). The capture prescaler is not used for triggering, so it does not need to be configured. The C1SEL bits select the input capture source. Set C1SEL = 01 in the TMRx\_CCM1 register. Write C1P = 1 in the TMRx\_CCE register to confirm the polarity (and detect low level only).

• Configure the timer as gated mode by writing SMSEL = 101 in the TMRx\_SMC register. Select TI1 as the input source by writing TRGSEL = 101 in the TMRx\_SMC register.

• Enable the counter by writing CNTEN = 1 in the TMRx\_CTRL1 register. In gated mode, the counter cannot be enabled if CNTEN = 0, no matter what the trigger input level is.

The counter starts counting on the internal clock as long as TI1 is low and stops as soon as TI1 becomes high. The TRGIF flag in the TMRx\_STS register is set both when the counter starts and stops.



The delay between the rising edge on TI1 and the actual stop of the counter is determined by the resynchronization circuit on TI1 input.

Figure 10-48 Control Circuit in Gated Mode



#### Slave mode: Trigger mode

The counter can be enabled according to the selected level of input.

In the following example, the counter starts to count up at rising edge on TI2 input:

• Configure channel 2 to detect the rising edge on TI2. Configure the input filter duration (in this example, no filter is needed, so keep IC1DF = 0000). The capture prescaler is not used for triggering, so it does not need to be configured. The C2SEL bits are only used to select the input capture source. Set C2SEL = 01 in the TMRx\_CCM1 register. Write C2P = 0 in the TMRx\_CCE register to confirm the polarity (and detect low level only).

• Configure the timer as trigger mode by writing SMSEL = 110 in the TMRx\_SMC register. Select TI2 as the input source by writing TRGSEL = 110 in the TMRx\_SMC register.

The counter starts counting on the internal clock as long as a rising edge occurs on TI2, and at the same time the TRGIF flag is set.

The delay between the rising edge on TI2 and enabling counting is determined by the resynchronization circuit on TI2 input.

Figure 10-49 Control Circuit in Trigger Mode



| TI2                                |    |               |
|------------------------------------|----|---------------|
| CNT_EN                             |    | _             |
| Counter clock = CK_CNT =<br>CK_DIV |    |               |
| Counter register                   | 34 | X35X36X37X38X |
| TRGIF                              |    |               |

#### Slave mode: External Clock Mode 2 + Trigger Mode

The external clock mode 2 can be used with another slave mode (except for external clock mode 1 and encoder mode). In this case, the ETR signal is used as external clock input, and another input can be trigger input in reset mode, gated mode, or trigger mode. Selecting ETR as TRGI through the TRGSEL bits in the TMRx\_SMC register is not recommended.

In the following example, as soon as a rising edge of TI1 occurs, the counter counts up once at each

rising edge of the ETR signal:

1. Configure the external trigger input circuit through the TMRx\_SMC register:

- ETDF = 0000: No filter

- ETD = 00: Prescaler is disabled.

- ETRGP = 0: Detect the rising edges on ETR and set ECLKEN = 1 to enable the external clock mode

2.

2. Configure channel 1 as follows to detect the rising edges on TI:

- IC1DF = 0000: No filter

- The capture prescaler is not used for triggering and does not need to be configured.

- Set C1SEL = 01 in the TMRx\_CCM1 register to select the input capture source

- Set C1P = 0 in the TMRx\_CCE register to confirm polarity (and detect rising edge only)

3. Configure the timer as trigger mode by writing SMSEL = 110 in the TMRx\_SMC register. Select TI1 as the input source by writing TRGSEL = 101 in the TMRx\_SMC register.

A rising edge on TI1 enables the counter and sets the TRGIF flag. The counter then counts on ETR rising



edges. The delay between the rising edge of the ETR signal and the actual reset of the counter is determined by the resynchronization circuit on ETRP input.

Figure 10-50 Control Circuit in External Clock Mode 2 + Trigger Mode



### 10.2.3.15 Timer Synchronization

All TMRx timers are linked together internally for timer synchronization or chaining. When one timer is configured in master mode, it can reset, start, stop, or clock the counter of another timer in slave mode.

Figure 10-51 shows an overview of the trigger selection and the master mode selection blocks.

#### Using one timer as the prescaler for another timer

Figure 10-51 Master/Slave Timer Example



For example, the user can configure Timer 1 to act as a prescaler for Timer 2. Please refer to Figure 10-51, and use the following procedure:

• Configure Timer 1 as master mode so that it can output a periodic trigger signal on each



update event UEV. If MMSEL = '010' in the TMR1\_CTRL2 register, a rising edge is outputted on TRGO1 each time when an update event is generated.

• To connect the TRGO1 output of Timer 1 to Timer 2, set TRGSEL = '000' in the TMR2\_SMC register, and Timer 2 must be configured in slave mode using ITR1 as internal trigger.

• Then, set the slave mode controller in external clock mode 1 (SMSEL = 111 in the TMR2\_SMC register). In this way, Timer 2 can be clocked by the periodic rising edge (Timer 1 counter overflow) trigger signal of Timer 1.

• Finally, both timers must be enabled by setting their corresponding CNTEN bits respectively (TMRx\_CTRL1 register).

Note: If OCx is selected on Timer 1 as trigger output (MMSEL = 1xx), its rising edge is used to clock the counter of Timer 2.

#### Using one timer to enable another timer

In this example, the enable of Timer 2 is controlled by the output compare of Timer 1. Please refer to Figure 10-51 for the connections. Timer 2 counts on the divided internal clock only when OC1REF of Timer 1 is high. Both counter clock frequencies are obtained through the prescaler which divides CK\_INT by 3 ( $f_{CK\_CNT} = f_{CK\_INT}/3$ ).

- Configure Timer 1 as master mode to send its output compare reference signal (OC1REF) as trigger output (MMSEL = 100 in the TMR1\_CTRL2 register).
- Configure the Timer 1 OC1REF waveform (TMR1\_CCM1 register)
- Configure Timer 2 to get the input trigger from Timer 1 (TRGSEL = 000 in the TMR2\_SMC register).
- Configure Timer 2 as gated mode (SMSEL = 101 in the TMR2\_SMC register).
- Set CNTEN = 1 in the TMR2\_CTRL1 register to enable Timer 2.
- Set CNTEN = 1 in the TMR1\_CTRL1 register to start Timer 1.

*Note:* The Timer 2 clock is not synchronized with Timer 1 clock. This mode only affects the Timer 2 counter enable signal.

Figure 10-52 Timer 1 OC1REF Controls Timer 2





In Figure 10-52, Timer 2 counter and prescaler are not initialized before Timer 2 is started, so they start counting from their current values. It is possible to start from a given value by resetting both timers before starting Timer 1. Then write any value desired in the timer counters. The timers can be reset just by writing the UEVG bit in the TMRx\_EVEG registers.

In the following example, Timer 1 and Timer 2 need to be synchronized. Timer 1 is the master and starts from 0. Timer 2 is the slave and starts from 0xE7. The prescaler ratio is the same for both timers. Timer 2 stops when Timer 1 is disabled by writing '0' to the CNTEN bit in the TMR1\_CTRL1 register:

- Configure Timer 1 as master mode to send its output compare 1 reference signal (OC1REF) as trigger output (MMSEL = 100 in the TMR1\_CTRL2 register).
- Configure the Timer 1 OC1REF waveform (TMR1\_CCM1 register).
- Configure Timer 2 to get the input trigger from Timer 1 (TRGSEL = 000 in the TMR2\_SMC register).
- Configure Timer 2 as gated mode (SMSEL = 101 in TMR2\_SMC register).
- Set UEVG = `1' in the TMR1\_EVEG register to reset Timer 1.
- Set UEVG = `1' in the TMR2\_EVEG register to reset Timer 2.
- Initialize Timer 2 to 0xE7 by writing '0xE7' to the timer 2 counter (TMR2\_CNT).
- Set CNTEN = '1' in the TMR2\_CTRL1 register to enable Timer 2.
- Set CNTEN = '1' in the TMR1\_CTRL1 register to start Timer 1.
- Set CNTEN = '0' in the TMR1\_CTRL1 register to stop Timer 1.

Figure 10-53 Control Timer 2 by Enabling Timer 1





#### Using one timer to start another timer

In this example, Timer 1 update event is used to enable Timer 2. Please refer to Figure 10-51 for the connections. Timer 2 starts counting from its current value (can be nonzero) on the divided internal clock once an update event is generated by Timer 1. When Timer 2 receives the trigger signal, its CNTEN bit is automatically set, and the counter starts counting until writing '0' to the CNTEN bit in the TMR2\_CTRL1 register. Both counter clock frequencies are divided by the prescaler which divides CK\_INT by 3 ( $f_{CK_CNT} = f_{CK_INT}/3$ ).

- Configure Timer 1 as master mode to send its update event (UEV) as trigger output (MMSEL = 010 in the TMR1\_CTRL2 register).
- Configure the Timer 1 period (TMR1\_AR register).
- Configure Timer 2 to get the input trigger from Timer 1 (TRGSEL = 000 in the TMR2\_SMC register).
- Configure Timer 2 as trigger mode (SMSEL = 110 in the TMR2\_SMC register)
- Set CNTEN = 1 in the TMR1\_CTRL1 register to start Timer 1.

Figure 10-54 Using Timer 1 Update to Trigger Timer 2





As in the above example, both counters can be initialized before starting counting. Figure 10-55 shows the behavior with the same configuration as the above example, but using trigger mode instead of gated mode (SMSEL = 110 in the TMR2\_SMC register).

Figure 10-55 Using Timer 1 Enable to Trigger Timer 2



#### Using one timer as the prescaler for another timer

In this example, Timer 1 is used as the prescaler of Timer 2. Please refer to Figure 10-51 for the connections, and the configuration is as follows:

• Configure Timer 1 as master mode to send its update event (UEV) as trigger output (MMSEL =



Hangzhou Vango Technologies, Inc.

010 in the TMR1\_CTRL2 register).

- Configure the Timer 1 period (TMR1\_AR register).
- Configure Timer 2 to get the input trigger f rom Timer 1 (TRGSEL = 000 in the TMR2\_SMC register).
- Configure Timer 2 to use external clock mode (SMSEL = 111 in the TMR2\_SMC register)
- Set CNTEN = 1 in the TMR1\_CTRL2 register to start Timer 2.
- Set CNTEN = 1 in the TMR1\_CTRL1 register to start Timer 1.

#### Starting two timers synchronously by an external trigger

In this example, when Timer 1 TI1 input rises, enable Timer 1, and at the same time Timer 2 is enabled. Please refer to Figure 10-51. To ensure that the counters are aligned, Timer 1 must be configured in master/slave mode (slave to TI1, master to Timer 2):

• Configure Timer 1 as master mode to send its enable as trigger output (MMSEL = '001' in the TMR1\_CTRL2 register).

• Configure Timer 1 as slave mode to get the input t rigger from TI1 (TRGSEL = `100' in the TMR1\_SMC register).

- Configure Timer 1 as trigger mode (SMSEL = '110' in the TMR1\_SMC register).
- Configure Timer 1 as master/slave mode, MSMODE = '1' in the TMR1\_SMC register.

• Configure Timer 2 to get the input trigger from Timer 1 (TRGSEL = 000 in the TMR2\_SMC register).

• Configure Timer 2 as trigger mode (SMSEL = '110' in the TMR2\_SMC register). When a rising edge occurs on TI1 of Timer 1, both timers start counting synchronously on the internal clock, and both TRGIF flags are set.

*Note:* In this example, both timers are initialized before starting (by setting the corresponding UEVG bits). Both counters start from 0, but an offset can be inserted between them by writing any of the counter registers (TMRx\_CNT).

In Figure 10-56, there is a delay between CNT\_EN and CK\_DIV on Timer 1 in master/slave mode.

Figure 10-56 Using Timer 1 TI1 Input to Trigger Timer 1 and Timer 2



| CK_INT                       |    | nnnnnn                                  |
|------------------------------|----|-----------------------------------------|
| TIMER 1-TI1                  |    |                                         |
| TIMER1-CNT_INIT              |    |                                         |
| TIMER 1-CK_DIV               |    |                                         |
| TIMER1-CNT                   | 00 | <u>X01X02X03X04X05X06X07X08X99X</u>     |
| TIMER1-TRGIF                 |    |                                         |
| TIMER2-CEN = CNT_EN          |    |                                         |
| TIMER 2-CK_DIV<br>TIMER2-CNT |    | <br>X01)02 X03/04 X 05/06 \07 X 08/09 X |
| TIMER2-TRGIF                 |    |                                         |

### 10.2.3.16 Debug Mode

When the microcontroller enters debug mode (Cortex<sup>®</sup>-M4F core halted), the TMRx counter either continues to work normally or stops, depending on DBG\_TMRx\_STOP configuration in DBG module. For more details, please refer to Section 20.2.2.

## **10.2.4 TMRx Registers Description**

## 10.2.4.1 Control Register 1 (TMRx\_CTRL1)

Address offset: 0x00

Reset value: 0x0000

| Bit       | Name | Туре | Description                                           |
|-----------|------|------|-------------------------------------------------------|
| Bit 15:11 | -    | -    | Reserved. Always read as 0.                           |
|           |      |      | Plus Mode Enable                                      |
| Bit 10    | PMEN | rw   | Enable TMRx plus mode. In this mode, TMRx_CNT,        |
|           |      |      | TMRx_AR, and TMRx_CC1/2/3/4 are expanded from 16 bits |



|         |             |    | to 32 bits.                                                  |
|---------|-------------|----|--------------------------------------------------------------|
|         |             |    | 0: Plus mode is not enabled.                                 |
|         |             |    | 1: Plus mode is enabled.                                     |
|         |             |    | Note: Only TMR2 and TMR5 have this function. This bit is     |
|         |             |    | invalid in other TMRs.                                       |
|         |             |    | Clock division                                               |
|         |             |    | Define the division ratio between the timer clock (CK_INT)   |
|         |             |    | frequency and sampling frequency used by the digital filters |
|         |             |    | (ETR, TIx).                                                  |
| Bit 9:8 | CLKDIV[1:0] | rw | 00: t <sub>dts</sub> = t <sub>ck_int</sub>                   |
|         |             |    | 01: t <sub>DTS</sub> = 2 x t <sub>CK_INT</sub>               |
|         |             |    | 10: t <sub>DTS</sub> = 4 x t <sub>CK_INT</sub>               |
|         |             |    | 11: Reserved                                                 |
| -       |             |    | Auto-reload preload enable                                   |
| Bit 7   |             | rw |                                                              |
|         | ARPEN       |    | 0: TMRx_AR register is not buffered.                         |
|         |             |    | 1: TMRx_AR register is buffered.                             |
|         |             |    | Center-aligned mode selection                                |
|         |             |    | 00: Edge-aligned mode. The counter counts up or down         |
|         |             |    | depending on the direction bit (DIR).                        |
|         |             | rw | 01: Center-aligned mode 1. The counter counts up and down    |
|         |             |    | alternatively. Output compare interrupt flags of channels    |
|         |             |    | configured as output (CxSEL = 00 in the $TMRx\_CCMx$         |
|         |             |    | register) are set only when the counter is counting down.    |
| Bit 6:5 | CMSEL[1:0]  |    | 10: Center-aligned mode 2. The counter counts up and down    |
|         |             |    | alternatively. Output compare interrupt flags of channels    |
|         |             |    | configured as output (CxSEL = 00 in the TMRx_CCMx            |
|         |             |    | register) are set only when the counter is counting up.      |
|         |             |    | 11: Center-aligned mode 3. The counter counts up and down    |
|         |             |    | alternatively. Output compare interrupt flags of channels    |
|         |             |    | configured as output (CxSEL = 00 in the TMRx_CCMx            |
|         |             |    | register) are set both when the counter is counting up or    |
|         | •           |    |                                                              |



|       |        |               | down.                                                          |
|-------|--------|---------------|----------------------------------------------------------------|
|       |        |               | Note: It is not allowed to switch from edge-aligned mode to    |
|       |        |               | center-aligned mode when the counter is enabled (CNTEN =       |
|       |        |               | 1).                                                            |
|       |        |               | Direction                                                      |
|       |        |               | 0: The counter counts up.                                      |
| Bit 4 | DIR    | rw            | 1: The counter counts down.                                    |
|       |        |               | Note: This bit is read-only when the counter is configured in  |
|       |        |               | center-aligned mode or encoder mode.                           |
|       |        |               | One pulse mode                                                 |
| Bit 3 | OPMODE | rw            | 0: The counter does not stop at update event.                  |
|       |        |               | 1: The counter stops at the next update event.                 |
|       |        |               |                                                                |
|       |        |               | Update request source                                          |
|       |        |               | This bit is set and cleared by software to select the UEV      |
|       |        |               | event sources.                                                 |
|       |        |               | 0: Any of the following events generates an update             |
|       |        |               | interrupt or DMA request if update interrupt or DMA request    |
| D:+ 0 |        |               | is enabled:                                                    |
| Bit 2 | UEVRS  | rw            | <ul> <li>Counter overflow/underflow</li> </ul>                 |
|       |        |               | <ul> <li>Setting the UEVG bit</li> </ul>                       |
|       |        |               | <ul> <li>An update is generated from the slave mode</li> </ul> |
|       |        |               | controller.                                                    |
|       |        |               | 1: Only counter overflow/underflow generates an update         |
|       |        |               | interrupt or DMA request if update interrupt or DMA request    |
|       |        |               | is enabled.                                                    |
|       |        |               | Update disable                                                 |
|       |        |               | This bit is set and cleared by software to enable/disable UEV  |
| Bit 1 | UEVDIS | <b>1714</b> / | event generation.                                              |
|       |        | rw            | 0: UEV is enabled. An update event (UEV) is generated by       |
|       |        |               | any of the following events:                                   |
|       |        |               | - Counter overflow/underflow                                   |



|       |       |    | - Setting the UEVG bit                                         |
|-------|-------|----|----------------------------------------------------------------|
|       |       |    | – An update is generated from the slave mode                   |
|       |       |    | controller. Buffered registers are loaded with their           |
|       |       |    | preload values.                                                |
|       |       |    | 1: UEV is disabled. Update events are not generated, and       |
|       |       |    | shadow registers (AR, DIV, and CCx) keep their values. The     |
|       |       |    | counter and the prescaler are reinitialized if the UEVG bit is |
|       |       |    | set or the slave mode controller sends a hardware reset.       |
|       |       |    | Counter enable                                                 |
|       |       |    | 0: The counter is disabled.                                    |
|       |       |    | 1: The counter is enabled.                                     |
|       |       |    | Note: External clock, gated mode, and encoder mode can         |
| Bit 0 | CNTEN | rw | work only after the CNTEN bit is previously set by software.   |
|       |       |    | Trigger mode can set the CNTEN bit automatically by            |
|       |       |    | hardware.                                                      |
|       |       |    | CNTEN is cleared automatically in one-pulse mode when an       |
|       |       |    | update event occurs.                                           |

# 10.2.4.2 Control Register 2 (TMRx\_CTRL2)

Address offset: 0x04

Reset value: 0x0000

| Bit                | Name            | Туре                                                                | Description                                               |                       |
|--------------------|-----------------|---------------------------------------------------------------------|-----------------------------------------------------------|-----------------------|
| Bit 15:8           | -               | -                                                                   | Reserved. Always read as 0.                               |                       |
|                    |                 |                                                                     | TI1 selection                                             |                       |
|                    | Bit 7 TI1SEL rv | rw                                                                  | 0: TMRx_CH1 pin is connected to TI1 input.                |                       |
| Bit 7              |                 |                                                                     | 1: TMRx_CH1, TMRx_CH2, and TMRx_CH3 pins are connected to |                       |
|                    |                 |                                                                     | the TI1 input after XORed.                                |                       |
|                    |                 |                                                                     | Please refer to Section 10.4.3.18.                        |                       |
|                    |                 |                                                                     |                                                           | Master mode selection |
| Bit 6:4 MMSEL[2:0] | rw              | The 3 bits select the synchronization information (TRGO) to be sent |                                                           |                       |



|         |       | I  |                                                                       |
|---------|-------|----|-----------------------------------------------------------------------|
|         |       |    | from master mode to slave timers. The possible combinations are       |
|         |       |    | as follows:                                                           |
|         |       |    | 000: Reset – The UEVG bit in the TMRx_EVEG register is used as        |
|         |       |    | trigger output (TRGO). If the reset is generated by the trigger input |
|         |       |    | (slave mode controller is in reset mode), the signal on TRGO is       |
|         |       |    | delayed compared with the actual reset.                               |
|         |       |    | 001: Enable – The counter enable signal, CNT_EN, is used as trigger   |
|         |       |    | output (TRGO). It is useful to start several timers at the same time  |
|         |       |    | or to control a window in which a slave timer is enabled. The counter |
|         |       |    | enable signal is generated by a logic OR between CNTEN control bit    |
|         |       |    | and the trigger input signal in gated mode.                           |
|         |       |    | When the counter enable signal is controlled by the trigger input,    |
|         |       |    | there is a delay on TRGO, unless the master/slave mode is selected    |
|         |       |    | (Please refer to the MSMODE bit description in the TMRx_SMC           |
|         |       |    | register).                                                            |
|         |       |    | 010: Update – The update event is selected as trigger output          |
|         |       |    | (TRGO). For instance, a master timer can be used as a prescaler for   |
|         |       |    | a slave timer.                                                        |
|         |       |    | 011: Compare Pulse – After a capture or a compare match occurs,       |
|         |       |    | the trigger output sends a positive pulse (TRGO) when the C1IF flag   |
|         |       |    | is to be set (even if it is already high).                            |
|         |       |    | 100: Compare – OC1REF signal is used as trigger output (TRGO).        |
|         |       |    | 101: Compare – OC2REF signal is used as trigger output (TRGO).        |
|         |       |    | 110: Compare – OC3REF signal is used as trigger output (TRGO).        |
|         |       |    | 111: Compare – OC4REF signal is used as trigger output (TRGO).        |
|         |       |    | Capture/Compare DMA selection                                         |
| Bit 3   | CDSEL | rw | 0: CCx DMA request is sent when CCx event occurs.                     |
|         |       |    | 1: CCx DMA request is sent when update event occurs.                  |
| Bit 2:0 | _     | -  | Reserved. Always read as 0.                                           |
|         |       |    | ,                                                                     |

# **10.2.4.3** Slave Mode Control Register (TMRx\_SMC)

Address offset: 0x08



#### Reset value: 0x0000

| Bit       | Name     | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15    | ETRGP    | rw   | <ul> <li>External trigger polarity</li> <li>This bit selects whether ETR or inverted ETR is used for trigger operations.</li> <li>0: ETR is non-inverted and active at high level or rising edge.</li> <li>1: ETR is inverted and active at low level or falling edge.</li> <li>External clock enable</li> <li>This bit enables external clock mode 2.</li> <li>0: External clock mode 2 is disabled</li> </ul>                                                                                                                                                                                                                                               |
| Bit 14    | ECLKEN   | rw   | 1: External clock mode 2 is enabled. The counter is clocked<br>by any active edge on the ETRF signal.<br>Note 1: Setting the ECLKEN bit has the same effect as<br>selecting external clock mode 1 with TRGI connected to ETRF<br>(SMSEL = 111 and TRGSEL = 111).<br>Note 2: It is possible to simultaneously use external clock<br>mode 2 with the following slave modes: reset mode, gated<br>mode, and trigger mode. Nevertheless, TRGI must not be<br>connected to ETRF in this case (TRGSEL bits must not be<br>111).<br>Note 3: If external clock mode 1 and external clock mode 2<br>are enabled at the same time, the external clock input is<br>ETRF. |
| Bit 13:12 | ETD[1:0] | rw   | External trigger prescaler<br>External trigger signal ETRP frequency must be 1/4 of<br>CK_INT frequency at most. A prescaler can be used to<br>reduce ETRP frequency when inputting faster external<br>clocks.<br>00: Prescaler is OFF.<br>01: ETRP frequency is divided by 2.                                                                                                                                                                                                                                                                                                                                                                                |



|          |             |    | 10: ETRP frequency is divided by 4.                                |
|----------|-------------|----|--------------------------------------------------------------------|
|          |             |    | 11: ETRP frequency is divided by 8.                                |
|          |             |    | External trigger filter                                            |
|          |             |    | The bits define the frequency used to sample TETRP signal          |
|          |             |    | and the length of ETRP digital filter. In fact, the digital filter |
|          |             |    | is an event counter which records N consecutive events that        |
|          |             |    | are needed to generate a transition on the output:                 |
|          |             |    | 0000: No filter, sampling is done at fDTS                          |
|          |             |    | 0001: $f_{\text{SAMPLING}} = f_{CK_{\text{INT}}}, N = 2$           |
|          |             |    | 0010: $f_{\text{SAMPLING}} = f_{\text{CK}_{\text{INT}}}$ , $N = 4$ |
|          |             |    | 0011: fsampling = fck_int, N = 8                                   |
|          |             |    | 0100: $f_{SAMPLING} = f_{DTS}/2, N = 6$                            |
| Bit 11:8 | ETDF[3:0]   | rw | 0101: $f_{SAMPLING} = f_{DTS}/2$ , N = 8                           |
|          |             |    | 0110: $f_{SAMPLING} = f_{DTS}/4$ , N = 6                           |
|          |             |    | 0111: $f_{SAMPLING} = f_{DTS}/4, N = 8$                            |
|          |             |    | 1000: f <sub>SAMPLING</sub> = f <sub>DTS</sub> /8, N = 6           |
|          |             |    | 1001: f <sub>SAMPLING</sub> = f <sub>DTS</sub> /8, N = 8           |
|          |             |    | 1010: $f_{SAMPLING} = f_{DTS} / 16, N = 5$                         |
|          |             |    | 1011: $f_{SAMPLING} = f_{DTS} / 16$ , N = 6                        |
|          |             |    | 1100: $f_{SAMPLING} = f_{DTS} / 16, N = 8$                         |
|          |             |    | 1101: $f_{SAMPLING} = f_{DTS} / 32, N = 5$                         |
|          |             |    | 1110: $f_{SAMPLING} = f_{DTS}/32, N = 6$                           |
|          |             |    | 1111: fsampling = fdts/32, N = 8                                   |
|          |             |    | Master/Slave mode                                                  |
|          |             |    | 0: No effect                                                       |
|          |             |    | 1: The event on the trigger input (TRGI) is delayed to allow       |
| Bit 7    | MSMODE      | rw | a perfect synchronization between the current timer and its        |
|          |             |    | slaves (through TRGO). It is useful when synchronizing             |
|          |             |    | several timers on a single external event.                         |
|          |             |    | Trigger selection                                                  |
| Bit 6:4  | TRGSEL[2:0] | rw | The bits select the trigger input used to synchronize the          |
|          |             |    | The site select the trigger input used to synchronize the          |



|         |            |    | counter.                                                     |
|---------|------------|----|--------------------------------------------------------------|
|         |            |    |                                                              |
|         |            |    | 000: Internal Trigger 0 (ITR0), TMR1                         |
|         |            |    | 001: Internal Trigger 1 (ITR1), TMR2                         |
|         |            |    | 010: Internal Trigger 2 (ITR2), TMR3                         |
|         |            |    | 011: Internal Trigger (ITR3), TMR4                           |
|         |            |    | 100: TI1 Edge Detector (TI1F_ED)                             |
|         |            |    | 101: Filtered Timer Input 1 (TI1FP1)                         |
|         |            |    | 110: Filtered Timer Input 2 (TI2FP2)                         |
|         |            |    | 111: External Trigger Input (ETRF)                           |
|         |            |    | Please refer to Table 10-2 for the details on ITRx for each  |
|         |            |    | timer.                                                       |
|         |            |    | Note: These bits must be changed only when they are not      |
|         |            |    | used (e.g. when SMSEL = 000) to avoid wrong edge             |
|         |            |    | detections at transitions.                                   |
| Bit 3   |            | -  | Reserved. Always read as 0.                                  |
|         |            |    | Slave mode selection                                         |
|         |            |    | When external signals are selected, the active edge of the   |
|         |            |    | trigger signal (TRGI) is relevant to the selected external   |
|         |            |    | input polarity (Please refer to input control register and   |
|         |            |    | control register description.)                               |
|         |            |    | 000: Slave mode is disabled - If $CNTEN = 1$ , the prescaler |
|         |            |    | is clocked directly by the internal clock.                   |
|         |            |    | 001: Encoder mode 1 - Counter counts up/down on TI1FP1       |
| Bit 2:0 | SMSEL[2:0] | rw | edge depending on TI2FP2 level.                              |
|         |            |    | 010: Encoder mode 2 - Counter counts up/down on TI2FP2       |
|         |            |    | edge depending on TI1FP1 level.                              |
|         |            |    | 011: Encoder mode 3 - Counter counts up/down on both         |
|         |            |    | TI1FP1 and TI2FP2 edges depending on the level of the        |
|         |            |    | other input.                                                 |
|         |            |    | 100: Reset Mode - Rising edge of the selected trigger input  |
|         |            |    | (TRGI) reinitializes the counter and generates an update     |
|         |            |    | register signal.                                             |
|         | 1          | 1  |                                                              |



| 101: Gated Mode - The counter clock is enabled when the trigger input (TRGI) is high. The counter stops (but is not reset) once the trigger becomes low. Both start and stop of the counter are controlled.         110: Trigger Mode - The counter starts at a rising edge of the trigger input TRGI (but it is not reset). Only the start of the counter is controlled.         111: External Clock Mode 1 - Rising edges of the selected trigger input (TRGI) clocks the counter.         Note: The gated mode must not be used if TI1F_EN is selected as the trigger input (TRGSEL = 100). This is because, TI1F_ED outputs 1 pulse for each transition on TI1F, whereas the gated mode checks the level of the trigger input signal. |                                                                 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| reset) once the trigger becomes low. Both start and stop of<br>the counter are controlled.<br>110: Trigger Mode - The counter starts at a rising edge of<br>the trigger input TRGI (but it is not reset). Only the start of<br>the counter is controlled.<br>111: External Clock Mode 1 - Rising edges of the selected<br>trigger input (TRGI) clocks the counter.<br><i>Note: The gated mode must not be used if TI1F_EN is</i><br><i>selected as the trigger input (TRGSEL = 100). This is</i><br><i>because, TI1F_ED outputs 1 pulse for each transition on</i><br><i>TI1F, whereas the gated mode checks the level of the</i>                                                                                                         | 101: Gated Mode - The counter clock is enabled when the         |
| the counter are controlled.<br>110: Trigger Mode - The counter starts at a rising edge of<br>the trigger input TRGI (but it is not reset). Only the start of<br>the counter is controlled.<br>111: External Clock Mode 1 - Rising edges of the selected<br>trigger input (TRGI) clocks the counter.<br>Note: The gated mode must not be used if TI1F_EN is<br>selected as the trigger input (TRGSEL = 100). This is<br>because, TI1F_ED outputs 1 pulse for each transition on<br>TI1F, whereas the gated mode checks the level of the                                                                                                                                                                                                    | trigger input (TRGI) is high. The counter stops (but is not     |
| 110: Trigger Mode - The counter starts at a rising edge of         the trigger input TRGI (but it is not reset). Only the start of         the counter is controlled.         111: External Clock Mode 1 - Rising edges of the selected         trigger input (TRGI) clocks the counter.         Note: The gated mode must not be used if TI1F_EN is         selected as the trigger input (TRGSEL = 100). This is         because, TI1F_ED outputs 1 pulse for each transition on         TI1F, whereas the gated mode checks the level of the                                                                                                                                                                                           | reset) once the trigger becomes low. Both start and stop of     |
| the trigger input TRGI (but it is not reset). Only the start of<br>the counter is controlled.<br>111: External Clock Mode 1 - Rising edges of the selected<br>trigger input (TRGI) clocks the counter.<br><i>Note: The gated mode must not be used if TI1F_EN is</i><br><i>selected as the trigger input (TRGSEL = 100). This is</i><br><i>because, TI1F_ED outputs 1 pulse for each transition on</i><br><i>TI1F, whereas the gated mode checks the level of the</i>                                                                                                                                                                                                                                                                     | the counter are controlled.                                     |
| the counter is controlled.<br>111: External Clock Mode 1 - Rising edges of the selected<br>trigger input (TRGI) clocks the counter.<br><i>Note: The gated mode must not be used if TI1F_EN is</i><br><i>selected as the trigger input (TRGSEL = 100). This is</i><br><i>because, TI1F_ED outputs 1 pulse for each transition on</i><br><i>TI1F, whereas the gated mode checks the level of the</i>                                                                                                                                                                                                                                                                                                                                        | 110: Trigger Mode - The counter starts at a rising edge of      |
| 111: External Clock Mode 1 - Rising edges of the selected         trigger input (TRGI) clocks the counter.         Note: The gated mode must not be used if TI1F_EN is         selected as the trigger input (TRGSEL = 100). This is         because, TI1F_ED outputs 1 pulse for each transition on         TI1F, whereas the gated mode checks the level of the                                                                                                                                                                                                                                                                                                                                                                         | the trigger input TRGI (but it is not reset). Only the start of |
| trigger input (TRGI) clocks the counter.<br><i>Note: The gated mode must not be used if TI1F_EN is</i><br><i>selected as the trigger input (TRGSEL = 100). This is</i><br><i>because, TI1F_ED outputs 1 pulse for each transition on</i><br><i>TI1F, whereas the gated mode checks the level of the</i>                                                                                                                                                                                                                                                                                                                                                                                                                                   | the counter is controlled.                                      |
| Note: The gated mode must not be used if TI1F_EN is<br>selected as the trigger input (TRGSEL = 100). This is<br>because, TI1F_ED outputs 1 pulse for each transition on<br>TI1F, whereas the gated mode checks the level of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 111: External Clock Mode 1 - Rising edges of the selected       |
| selected as the trigger input (TRGSEL = 100). This is<br>because, TI1F_ED outputs 1 pulse for each transition on<br>TI1F, whereas the gated mode checks the level of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | trigger input (TRGI) clocks the counter.                        |
| because, TI1F_ED outputs 1 pulse for each transition on<br>TI1F, whereas the gated mode checks the level of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Note: The gated mode must not be used if TI1F_EN is             |
| TI1F, whereas the gated mode checks the level of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | selected as the trigger input (TRGSEL = 100). This is           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | because, TI1F_ED outputs 1 pulse for each transition on         |
| trigger input signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | TI1F, whereas the gated mode checks the level of the            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | trigger input signal.                                           |

Table 10-2 TMRx Internal Trigger Connection (1)

| Slave | ITR0           | ITR1           | ITR2           | ITR3           |
|-------|----------------|----------------|----------------|----------------|
| Timer | (TRGSEL = 000) | (TRGSEL = 001) | (TRGSEL = 010) | (TRGSEL = 011) |
| TMR2  | TMR1           | TMR8           | TMR3           | TMR4           |
| TMR3  | TMR1           | TMR2           | TMR5           | TMR4           |
| TMR4  | TMR1           | TMR2           | TMR3           | TMR8           |
| TMR5  | TMR2           | TMR3           | TMR4           | TMR8           |

*Note1: When a corresponding timer is not present in the product, the corresponding trigger ITRx is not available.* 

Note2: ITR1 can select TMR8 or USB\_SOF, which is controlled by the TMR2ITR1\_IRMP bit of AFIO\_MAP4

### **10.2.4.4 DMA/Interrupt Enable Register (TMRx\_DIE)**

Address offset: 0x0C

Reset value: 0x0000



| Bit    | Name  | Туре | Description                                   |
|--------|-------|------|-----------------------------------------------|
| Bit 15 | -     | -    | Reserved. Always read as 0.                   |
|        |       |      | Trigger DMA request enable                    |
| Bit 14 | TRGDE | rw   | 0: Trigger DMA request is disabled.           |
|        |       |      | 1: Trigger DMA request is enabled.            |
| Bit 13 | -     | -    | Reserved. Always read as 0.                   |
|        |       |      | Capture/Compare 4 DMA request enable          |
| Bit 12 | C4DE  | rw   | 0: Capture/Compare 4 DMA request is disabled. |
|        |       |      | 1: Capture/Compare 4 DMA request is enabled.  |
|        |       |      | Capture/Compare 3 DMA request enable          |
| Bit 11 | C3DE  | rw   | 0: Capture/Compare 3 DMA request is disabled. |
|        |       |      | 1: Capture/Compare 3 DMA request is enabled.  |
|        |       |      | Capture/Compare 2 DMA request enable          |
| Bit 10 | C2DE  | rw   | 0: Capture/Compare 2 DMA request is disabled. |
|        |       |      | 1: Capture/Compare 2 DMA request is enabled.  |
|        |       |      | Capture/Compare 1 DMA request enable          |
| Bit 9  | C1DE  | rw   | 0: Capture/Compare 1 DMA request is disabled. |
|        |       |      | 1: Capture/Compare 1 DMA request is enabled.  |
|        |       |      | Update DMA request enable                     |
| Bit 8  | UEVDE | rw   | 0: Update DMA request is disabled.            |
|        |       |      | 1: Update DMA request is enabled.             |
| Bit 7  | -     | rw   | Reserved. Always read as 0.                   |
|        |       |      | Trigger interrupt enable                      |
| Bit 6  | TRGIE | rw   | 0: Trigger interrupt is disabled.             |
|        |       |      | 1: Trigger interrupt is enabled.              |
| Bit 5  | -     | -    | Reserved. Always read as 0.                   |
| Bit 4  | C4IE  | rw   | Capture/Compare 4 interrupt enable            |



|       |       |    | 0: Capture/Compare 4 interrupt is disabled.<br>1: Capture/Compare 4 interrupt is enabled. |
|-------|-------|----|-------------------------------------------------------------------------------------------|
|       |       |    | Capture/Compare 3 interrupt enable                                                        |
| Bit 3 | C3IE  | rw | 0: Capture/Compare 3 interrupt is disabled.                                               |
|       |       |    | 1: Capture/Compare 3 interrupt is enabled.                                                |
|       |       |    | Capture/Compare 2 interrupt enable                                                        |
| Bit 2 | C2IE  | rw | 0: Capture/Compare 2 interrupt is disabled.                                               |
|       |       |    | 1: Capture/Compare 2 interrupt is enabled.                                                |
|       |       |    | Capture/Compare 1 interrupt enable                                                        |
| Bit 1 | C1IE  | rw | 0: Capture/Compare 1 interrupt is disabled.                                               |
|       |       |    | 1: Capture/Compare 1 interrupt is enabled.                                                |
|       |       |    | Update interrupt enable                                                                   |
| Bit 0 | UEVIE | rw | 0: Update interrupt is disabled.                                                          |
|       |       |    | 1: Update interrupt is enabled.                                                           |

# 10.2.4.5 Status Register (TMRx\_STS)

Address offset: 0x10

Reset value: 0x0000

| Bit       | Name | Туре | Description                                                                                                                                                  |
|-----------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:13 | -    | -    | Reserved. Always read as 0.                                                                                                                                  |
| Bit 12    | C4OF | rw   | Capture/Compare 4 overcapture flag Please refer to C1OF description.                                                                                         |
| Bit 11    | C30F | rw   | Capture/Compare 3 overcapture flag Please refer to C1OF description.                                                                                         |
| Bit 10    | C2OF | rw   | Capture/Compare 2 overcapture flag Please refer to C1OF description.                                                                                         |
| Bit 9     | C10F | rw   | Capture/Compare 1 overcapture flag<br>This flag is set by hardware only when the corresponding<br>channel is configured as input capture mode. It is cleared |



|         |       |    | by writing `0'.                                               |
|---------|-------|----|---------------------------------------------------------------|
|         |       |    | 0: No overcapture is detected.                                |
|         |       |    | 1: When the counter value is captured to the TMRx_CC1         |
|         |       |    | register, C1IF flag is already set.                           |
| Bit 8:7 | -     | -  | Reserved. Always read as 0.                                   |
|         |       |    | Trigger interrupt flag                                        |
|         |       |    | This flag is set by hardware on trigger event (When the slave |
|         |       |    | mode controller is in all modes except for gated mode, active |
| Bit 6   | TRGIF | rw | edge is detected on TRGI input, or any edge in the gated      |
|         |       |    | mode). It is cleared by software.                             |
|         |       |    | 0: No trigger event occurs.                                   |
|         |       |    | 1: Trigger interrupt is pending.                              |
| Bit 5   | -     | -  | Reserved. Always read as 0.                                   |
|         |       |    | Capture/Compare 4 interrupt flag Please refer to C1IF         |
| Bit 4   | C4IF  | rw | description.                                                  |
|         |       |    | Capture/Compare 3 interrupt flag Please refer to C1IF         |
| Bit 3   | C3IF  | rw | description.                                                  |
|         | 6215  | -  | Capture/Compare 2 interrupt flag Please refer to C1IF         |
| Bit 2   | C2IF  | rw | description.                                                  |
|         |       |    | Capture/Compare 1 interrupt flag                              |
|         |       |    | If channel CC1 is configured as output mode:                  |
|         |       |    | This flag is set by hardware when the counter value           |
|         |       | rw | matches the compare value, but not in center-aligned mode     |
| Bit 1 C |       |    | (Please refer to the CMSEL bits in the TMRx_CTRL1). It is     |
|         |       |    | cleared by software.                                          |
|         | C1IF  |    | 0: No match                                                   |
|         |       |    | 1: The TMRx_CNT value matches the TMRx_CC1 value.             |
|         |       |    | If channel CC1 is configured as input mode:                   |
|         |       |    | This bit is set by hardware on a capture. It is cleared by    |
|         |       |    | software or by reading the TMRx_CC1 register.                 |
|         |       |    | 0: No input capture occurs.                                   |
|         |       |    |                                                               |



|             |    | -                                                           |                                                                   |
|-------------|----|-------------------------------------------------------------|-------------------------------------------------------------------|
|             |    |                                                             | 1: The counter value is captured to the TMRx_CC1 register         |
|             |    |                                                             | (An edge which matches the selected polarity is detected on       |
|             |    |                                                             | IC1).                                                             |
|             |    |                                                             | Update interrupt flag                                             |
|             |    |                                                             | This bit is set by hardware on an update event. It is cleared     |
|             |    |                                                             | by software.                                                      |
|             |    |                                                             | 0: No update event occurs.                                        |
|             |    |                                                             | 1: Update interrupt is pending. This bit is set by hardware       |
|             |    |                                                             | when the registers are updated:                                   |
|             |    |                                                             | <ul> <li>If UEVDIS = 0 and UEVRS = 0 in the TMRx_CTRL1</li> </ul> |
| Bit 0 UEVIF | rw | register, an update event is generated when UEVG = 1 in the |                                                                   |
|             |    |                                                             | TMRx_EVEG register (the counter CNT is reinitialized by           |
|             |    |                                                             | software).                                                        |
|             |    |                                                             | <ul> <li>If UEVDIS = 0 and UEVRS = 0 in the TMRx_CTRL1</li> </ul> |
|             |    |                                                             | register, an update event is generated when the counter CNT       |
|             |    |                                                             | is reinitialized by trigger events (Please refer to the           |
|             |    |                                                             | description of synchronized control registers).                   |

## 10.2.4.6 Event Generation Register (TMRx\_EVEG)

Address offset: 0x14

Reset value: 0x0000

| Bit      | Name | Туре | Description                                                                                                                                                                                                                                          |
|----------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:7 | -    | -    | Reserved. Always read as 0.                                                                                                                                                                                                                          |
| Bit 6    | TRGG | rw   | Trigger generation<br>This bit is set by software to generate a trigger event. It is<br>cleared automatically by hardware.<br>0: No action<br>1: TRGIF = 1 in the TMRx_STS register, the corresponding<br>interrupt and DMA is generated if enabled. |
| Bit 5    | -    | -    | Reserved. Always read as 0.                                                                                                                                                                                                                          |



| Bit 4 | C4G  | rw | Capture/Compare 4 generation Please refer to C1G description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 3 | C3G  | rw | Capture/Compare 3 generation Please refer to C1G description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 2 | C2G  | rw | Capture/Compare 2 generation Please refer to C1G description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 1 | C1G  | rw | Capture/Compare 1 generation<br>This bit is set by software to generate a capture/compare<br>event. It is cleared automatically by hardware.<br>0: No action<br>1: A capture/compare event is generated on channel 1<br>CC1:<br>If channel CC1 is configured as output:<br>Set C1IF = 1. The corresponding interrupt and DMA request<br>is generated if enabled.<br>If channel CC1 is configured as input:<br>The current value of the counter is captured to the<br>TMRx_CC1 register. Set C1IF = 1. The corresponding<br>interrupt and DMA request is generated if enabled. If C1IF<br>is already `1', set C1OF = 1. |
| Bit 0 | UEVG | rw | Update generation<br>This bit can be set by software, and it is automatically<br>cleared by hardware.<br>0: No action<br>1: Re-initialize the counter and generate an update. Note<br>that the prescaler counter is cleared, too (but the prescaler<br>ratio is not affected). The counter is cleared if the center-<br>aligned mode is selected, or if DIR = 0 (upcounting), else it<br>takes the TMRx_AR value if DIR = 1 (downcounting).                                                                                                                                                                            |



## 10.2.4.7 Capture/Compare Mode Register 1 (TMRx\_CCM1)

Address offset: 0x18

Reset value: 0x0000

The channels can be used in input (capture mode) or in output (compare mode). The direction of a channel is defined by the corresponding CxSEL bits. All the other bits of this register have different functions in input and output modes. For a given bit, OCxx describes its function when the channel is in output mode, ICxx describes its function when the channel is in input mode. Attention must be given to the fact that the same bit can have a different meanings for the input stage and for the output stage.

#### Output compare mode:

| Bit       | Name         | Туре | Description                                                  |
|-----------|--------------|------|--------------------------------------------------------------|
| Bit 15    | OC2DIS       | rw   | Output compare 2 clear enable                                |
| Bit 14:12 | OC2MODE[2:0] | rw   | Output compare 2 mode                                        |
| Bit 11    | OC2PEN       | rw   | Output compare 2 preload enable                              |
| Bit 10    | OC2FEN       | rw   | Output compare 2 fast enable                                 |
|           |              |      | Capture/Compare 2 selection                                  |
|           |              |      | This bit defines the channel direction (input/output), and   |
|           |              |      | the selection of input pin:                                  |
|           |              |      | 00: CC2 channel is configured as output.                     |
|           |              |      | 01: CC2 channel is configured as input, IC2 is mapped on     |
|           |              |      | TI2.                                                         |
| Bit 9:8   | C2SEL[1:0]   | rw   | 10: CC2 channel is configured as input, IC2 is mapped on     |
|           |              |      | TI1.                                                         |
|           |              |      | 11: CC2 channel is configured as input, IC2 is mapped on     |
|           |              |      | TRC. This mode works only when the internal trigger input is |
|           |              |      | selected (by the TRGSEL bit in the TMRx_SMC register).       |
|           |              |      | Note: C2SEL can be written only when the channel is disabled |
|           |              |      | (C2EN = '0' in the TMRx_CCE register).                       |
|           |              |      | Output compare 1 clear enable                                |
| Bit 7     | Bit 7 OC1DIS | rw   | 0: OC1REF is not affected by ETRF input.                     |



| 1: Once high level is detected on ETRF input, clear OC1REF         = 0.         Output compare 1 enable         The bits define the behavior of the output reference signal         OC1REF, and OC1REF determines OC1 value. OC1REF is         active high, while active level of OC1 is determined by the         C1P bit.         000: Frozen. The comparison between the output compare         register TMRx_CC1 and the counter TMRx_CNT has no effect         on OC1REF.         001: Set channel 1 to active level on match. OC1REF is         forced high when the counter TMRx_CNT value matches the |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output compare 1 enable         The bits define the behavior of the output reference signal         OC1REF, and OC1REF determines OC1 value. OC1REF is         active high, while active level of OC1 is determined by the         C1P bit.         000: Frozen. The comparison between the output compare         register TMRx_CC1 and the counter TMRx_CNT has no effect         on OC1REF.         001: Set channel 1 to active level on match. OC1REF is                                                                                                                                                 |
| The bits define the behavior of the output reference signal<br>OC1REF, and OC1REF determines OC1 value. OC1REF is<br>active high, while active level of OC1 is determined by the<br>C1P bit.<br>000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect<br>on OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is                                                                                                                                                                                                                    |
| OC1REF, and OC1REF determines OC1 value. OC1REF is<br>active high, while active level of OC1 is determined by the<br>C1P bit.<br>000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect<br>on OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is                                                                                                                                                                                                                                                                                   |
| active high, while active level of OC1 is determined by the<br>C1P bit.<br>000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect<br>on OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is                                                                                                                                                                                                                                                                                                                                         |
| C1P bit.<br>000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect<br>on OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is                                                                                                                                                                                                                                                                                                                                                                                                        |
| 000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect<br>on OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is                                                                                                                                                                                                                                                                                                                                                                                                                    |
| register TMRx_CC1 and the counter TMRx_CNT has no effect<br>on OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| on OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 001: Set channel 1 to active level on match. OC1REF is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| forced high when the counter TMRX_CNT value matches the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Torced high when the counter thick_ent value matches the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| capture/compare register1 (TMRx_CC1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 010: Set channel 1 to inactive level on match. OC1REF is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| forced low when the counter TMRx_CNT value matches the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| capture/compare register1 (TMRx_CC1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 6:4 OC1MODE[2:0] rw 011: Toggle. Toggle OC1REF level whenTMRx_CC1 =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| TMRx_CNT.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 100: Force inactive level. OC1REF is forced low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 101: Force active level. OC1REF is forced high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 110: PWM mode $1-$ In upcounting, channel 1 is active once                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMRx_CNT < TMRx_CC1, else inactive; in down counting,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| channel 1 is inactive once TMRx_CNT > TMRx_CC1 (OC1REF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| = 0), else active (OC1REF $= 1$ ).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 111: PWM mode 2—In upcounting, channel 1 is inactive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| once TMRx_CNT < TMRx_CC1, else active; in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| downcounting, channel 1 is active once TMRx_CNT >                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| TMRx_CC1, else inactive.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Note: In PWM mode 1 or PWM mode 2, OC1REF level changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| only when the comparison result changes or when output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| compare mode switches from frozen mode to PWM mode .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 3 OC1PEN rw Output compare 1 preload enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |



|         |            |    | 0: Preload function of TMRx_CC1 is disabled. TMRx_CC1        |
|---------|------------|----|--------------------------------------------------------------|
|         |            |    | can be written at any time, and the new value takes effect   |
|         |            |    | immediately.                                                 |
|         |            |    | 1: Preload function of TMRx_CC1 is enabled. Read/Write       |
|         |            |    | operations only access the preload register. TMRx_CC1        |
|         |            |    | preload value is sent to the active register at each update  |
|         |            |    | event.                                                       |
|         |            |    | Note: The PWM mode can be used without validating the        |
|         |            |    | preload register only in one-pulse mode (OPMODE = `1' in     |
|         |            |    | the TMRx_CTRL1 register). Else, the behavior is not          |
|         |            |    | guaranteed.                                                  |
|         |            |    | Output compare 1 fast enable                                 |
|         |            | rw | This bit is used to accelerate the CC output's response to   |
|         |            |    | trigger the input event.                                     |
|         |            |    | 0: CC1 behaves normally with the counter and CC1 values      |
|         |            |    | even when the trigger is ON. When an active edge occurs      |
|         |            |    | on the trigger input, the minimum delay to activate CC1      |
| D:1-2   |            |    | output is 5 clock cycles.                                    |
| Bit 2   | OC1FEN     |    | 1: An active edge on the trigger input acts like a compare   |
|         |            |    | match. Therefore, OC is set to the compare level which is    |
|         |            |    | irrelevant to the result of the comparison. Delay to sample  |
|         |            |    | the trigger input and to activate CC1 output is reduced to 3 |
|         |            |    | clock cycles.                                                |
|         |            |    | This bit only acts when channel is configured as PWM1or      |
|         |            |    | PWM2 mode.                                                   |
|         |            |    | Capture/Compare 1 selection                                  |
|         |            |    | The bits define the channel direction (input/output), and    |
|         | C1SEL[1:0] | rw | input pin selection:                                         |
| Bit 1:0 |            |    | 00: CC1 channel is configured as output.                     |
|         |            |    | 01: CC1 channel is configured as input, IC1 is mapped on     |
|         |            |    | TI1.                                                         |
|         |            |    | 10: CC1 channel is configured as input, IC1 is mapped on     |
| Allh    |            |    |                                                              |



|  | TI2.                                                         |
|--|--------------------------------------------------------------|
|  | 11: CC1 channel is configured as input, IC1 is mapped on     |
|  | TRC. This mode works only when the internal trigger input is |
|  | selected (by the TRGSEL bit in the TMRx_SMC register).       |
|  | Note: C1SEL can be written only when the channel is disabled |
|  | (C1EN = '0' in the TMRx_CCE register).                       |

#### Input capture mode:

| Bit       | Name        | Туре | Description                                                          |
|-----------|-------------|------|----------------------------------------------------------------------|
| Bit 15:12 | IC2DF[3:0]  | rw   | Input capture 2 filter                                               |
| Bit 11:10 | IC2DIV[1:0] | rw   | Input capture 2 prescaler                                            |
|           |             |      | Capture/Compare 2 selection                                          |
|           |             |      | The bits define the channel direction (input/output), and            |
|           |             |      | input pin selection:                                                 |
|           |             |      | 00: CC2 channel is configured as output.                             |
|           |             |      | 01: CC2 channel is configured as input, IC2 is mapped on             |
|           |             |      | TI2.                                                                 |
| Bit 9:8   | C2SEL[1:0]  | rw   | 10: CC2 channel is configured as input, IC2 is mapped on             |
|           |             |      | TI1.                                                                 |
|           |             |      | 11: CC2 channel is configured as input, IC2 is mapped on             |
|           |             |      | TRC. This mode works only when the internal trigger input is         |
|           |             |      | selected (by the TRGSEL bit in the TMRx_SMC register).               |
|           |             |      | Note: C2SEL can be written only when the channel is disabled         |
|           |             |      | (C2EN = '0' in the TMRx_CCE register).                               |
|           |             |      | Input capture 1 filter                                               |
|           | IC1DF[3:0]  | rw   | The bits define the frequency used to sample TI1 input and           |
|           |             |      | the length of digital filter. The digital filter is an event counter |
|           |             |      | which records N consecutive events that are needed to                |
| Bit 7:4   |             |      | generate a transition on the output:                                 |
|           |             |      | 0000: No filter, sampling is done at $f_{\text{DTS}}$                |
|           |             |      | 0001: $f_{SAMPLING} = f_{CK_INT}$ , N = 2                            |
|           |             |      | 0010: $f_{\text{SAMPLING}} = f_{\text{CK}_{\text{INT}}}$ , $N = 4$   |



|         |             |    | 0011: $f_{SAMPLING} = f_{CK_INT}$ , $N = 8$                  |
|---------|-------------|----|--------------------------------------------------------------|
|         |             |    | 0100: $f_{SAMPLING} = f_{DTS}/2, N = 6$                      |
|         |             |    | 0101: fsampling = fdts/2, N= 8                               |
|         |             |    | 0110: $f_{SAMPLING} = f_{DTS}/4$ , N = 6                     |
|         |             |    | 0111: $f_{SAMPLING} = f_{DTS}/4$ , N = 8                     |
|         |             |    | 1000: f <sub>SAMPLING</sub> = f <sub>DTS</sub> /8, N = 6     |
|         |             |    | 1001: $f_{SAMPLING} = f_{DTS} / 8$ , N = 8                   |
|         |             |    | 1010: $f_{SAMPLING} = f_{DTS} / 16$ , N = 5                  |
|         |             |    | 1011: fsampling = fdts /16, N = 6                            |
|         |             |    | 1100:f <sub>SAMPLING</sub> = f <sub>DTS</sub> /16, N = 8     |
|         |             |    | 1101: fsampling = fdts /32, N = 5                            |
|         |             |    | 1110: fsampling = fdts/32, N = 6                             |
|         |             |    | 1111: fsampling = fdts/32, N = 8                             |
|         |             |    | Input capture 1 prescaler                                    |
|         | IC1DIV[1:0] | rw | The bits define CC1 input (IC1) prescaler ratio.             |
|         |             |    | Once C1EN = $0'$ (in the TMRx_CCE register), prescaler is    |
|         |             |    | reset.                                                       |
| Bit 3:2 |             |    | 00: No prescaler. Capture is done each time when an edge     |
|         |             |    | is detected on the capture input.                            |
|         |             |    | 01: Capture is done once every 2 events.                     |
|         |             |    | 10: Capture is done once every 4 events                      |
|         |             |    | 11: Capture is done once every 8 events.                     |
|         |             |    | Capture/Compare 1 selection                                  |
|         |             |    | The bits define the channel direction (input/output), and    |
|         |             |    | input pin selection:                                         |
|         | C1SEL[1:0]  | rw | 00: CC1 channel is configured as output.                     |
| Bit 1:0 |             |    | 01: CC1 channel is configured as input, IC1 is mapped on     |
|         |             |    | TI1.                                                         |
|         |             |    | 10: CC1 channel is configured as input, IC1 is mapped on     |
|         |             |    | TI2.                                                         |
|         |             |    | 11: CC1 channel is configured as input, IC1 is mapped on     |
|         |             |    | TRC. This mode works only when the internal trigger input is |
|         | I           | 1  | 1                                                            |

|  | selected (by the TRGSEL bit in the TMRx_SMC register).       |
|--|--------------------------------------------------------------|
|  | Note: C1SEL can be written only when the channel is disabled |
|  | (C1EN = '0' in the TMRx_CCE register).                       |

# 10.2.4.8 Capture/Compare Mode Register 2 (TMRx\_CCM2)

Address offset: 0x1C

Reset value: 0x0000

Please refer to the above-mentioned CCM1 register description.

#### Output compare mode:

| Bit       | Name         | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|--------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15    | OC4DIS       | rw   | Output compare 4 clear enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 14:12 | OC4MODE[2:0] | rw   | Output compare 4 mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 11    | OC4PEN       | rw   | Output compare 4 preload enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 10    | OC4FEN       | rw   | Output compare 4 fast enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 9:8   | C4SEL[1:0]   | rw   | Capture/Compare 4 selection<br>The bits define the channel direction (input/output), and<br>input pin selection:<br>00: CC4 channel is configured as output.<br>01: CC4 channel is configured as input, IC4 is mapped on<br>TI4.<br>10: CC4 channel is configured as input, IC4 is mapped on<br>TI3.<br>11: CC4 channel is configured as input, IC4 is mapped on<br>TRC. This mode works only when the internal trigger input is<br>selected (by the TRGSEL bit in the TMRx_SMC register).<br><i>Note: C4SEL can be written only when the channel is disabled</i><br><i>(C4EN = '0' in the TMRx_CCE register).</i> |
|           | 002016       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 7     | OC3DIS       | rw   | Output compare 3 clear enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 6:4   | OC3MODE[2:0] | rw   | Output compare 3 mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |



| Bit 3 OC3PEN       | rw | Output compare 3 preload enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 2 OC3FEN       | rw | Output compare 3 fast enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 1:0 C3SEL[1:0] | rw | Capture/Compare 3 selection<br>The bits define the channel direction (input/output), and<br>input pin selection:<br>00: CC3 channel is configured as output.<br>01: CC3 channel is configured as input, IC3 is mapped on<br>TI3.<br>10: CC3 channel is configured as input, IC3 is mapped on<br>TI4.<br>11: CC3 channel is configured as input, IC3 is mapped on<br>TRGI. This mode works only when the internal trigger input<br>is selected (by the TRGSEL bit in the TMRx_SMC register).<br><i>Note: C3SEL can be written only when the channel is disabled</i><br><i>(C3EN = '0' in the TMRx_CCE register).</i> |

#### Input capture mode:

| Bit       | Name        | Туре | Description                                                  |
|-----------|-------------|------|--------------------------------------------------------------|
| Bit 15:12 | IC4DF[3:0]  | rw   | Input capture 4 filter                                       |
| Bit 11:10 | IC4DIV[1:0] | rw   | Input capture 4 prescaler                                    |
| Bit 9:8   | C4SEL[1:0]  | rw   | Capture/compare 4 selection                                  |
|           |             |      | The bits define the channel direction (input/output), and    |
|           |             |      | input pin selection:                                         |
|           |             |      | 00: CC4 channel is configured as output.                     |
|           |             |      | 01: CC4 channel is configured as input, IC4 is mapped on     |
|           |             |      | TI4.                                                         |
|           |             |      | 10: CC4 channel is configured as input, IC4 is mapped on     |
|           |             |      | TI3.                                                         |
|           |             |      | 11: CC4 channel is configured as input, IC4 is mapped on     |
|           |             |      | TRC. This mode works only when the internal trigger input is |
|           |             |      | selected (by the TRGSEL bit in the TMRx_SMC register).       |



|             | n           |                                                              |
|-------------|-------------|--------------------------------------------------------------|
|             |             | Note: C4SEL can be written only when the channel is disabled |
|             |             | (C4EN = '0' in the TMRx_CCE register).                       |
|             |             |                                                              |
|             |             |                                                              |
|             |             |                                                              |
| IC3DF[3:0]  | rw          | Input capture 3 filter                                       |
| IC3DIV[1:0] | rw          | Input capture 3 prescaler                                    |
| C3SEL[1:0]  | rw          | Capture/Compare 3 selection                                  |
|             |             | The bits define the channel direction (input/output), and    |
|             |             | input pin selection:                                         |
|             |             | 00: CC3 channel is configured as output.                     |
|             |             | 01: CC3 channel is configured as input, IC3 is mapped on     |
|             |             | TI3.                                                         |
|             |             | 10: CC3 channel is configured as input, IC3 is mapped on     |
|             |             | TI4.                                                         |
|             |             | 11: CC3 channel is configured as input, IC3 is mapped on     |
|             |             | TRC. This mode works only when the internal trigger input is |
|             |             | selected (by the TRGSEL bit in the TMRx_SMC register).       |
|             |             | Note: C3SEL can be written only when the channel is disabled |
|             |             | (C3EN = '0' in the TMRx_CCE register).                       |
|             | IC3DIV[1:0] | IC3DIV[1:0] rw                                               |

# **10.2.4.9** Capture/Compare Enable Register (TMRx\_CCE)

Address offset: 0x20

| Bit       | Name | Туре | Description                                                        |
|-----------|------|------|--------------------------------------------------------------------|
| Bit 15:14 | -    | -    | Reserved. Always read as 0.                                        |
| Bit 13    | C4P  | rw   | Capture/Compare 4 output polarity Please refer to C1P description. |
| Bit 12    | C4EN | rw   | Capture/Compare 4 output enable Please refer to C1EN description.  |



|           | T    |    |                                                                    |
|-----------|------|----|--------------------------------------------------------------------|
| Bit 11:10 | -    | rw | Reserved. Always read as 0.                                        |
| Bit 9     | СЗР  | rw | Capture/Compare 3 output polarity Please refer to C1P description. |
| Bit 8     | C3EN | rw | Capture/Compare 3 output enable Please refer to C1EN description.  |
| Bit 7:6   | -    | -  | Reserved. Always read as 0.                                        |
| Bit 5     | C2P  | rw | Capture/Compare 2 output polarity Please refer to C1P description. |
| Bit 4     | C2EN | rw | Capture/Compare 2 output enable Please refer to C1EN description.  |
| Bit 3:2   | -    | -  | Reserved. Always read as 0.                                        |
| Bit 1     | C1P  | rw | Capture/Compare 1 output polarity                                  |
|           |      |    | CC1 channel is configured as output:                               |
|           |      |    | 0: OC1 is active high. 1: OC1 is active low.                       |
|           |      |    | CC1 channel is configured as input:                                |
|           |      |    | This bit selects whether IC1 or inverted IC1 is used for           |
|           |      |    | trigger or capture signal.                                         |
|           |      |    | 0: Not inverted: Capture is done on a rising edge of IC1.          |
|           |      |    | When used as external trigger, IC1 is not inverted.                |
|           |      |    | 1: Inverted: Capture is done on a falling edge of IC1. When        |
|           |      |    | used as external trigger, IC1 is inverted.                         |
| Bit 0     | C1EN | rw | Capture/Compare 1 output enable                                    |
|           |      |    | CC1 channel is configured as output:                               |
|           |      |    | 0: OFF – OC1 output is disabled.                                   |
|           |      |    | 1: ON- OC1 is outputted on the corresponding output pin.           |
|           |      |    | CC1 channel is configured as input:                                |
|           |      |    | This bit determines whether the counter value can be               |
|           |      |    | captured to TMRx_CC1 register.                                     |
|           |      |    | 0: Capture is disabled.                                            |
|           |      |    | 1: Capture is enabled.                                             |



#### Table 10-3 Standard OCx Channel Output Control Bit

| CxEN Bit | OCx Output State                      |
|----------|---------------------------------------|
| 0        | Output disabled (OCx = 0, OCx_EN = 0) |
| 1        | $OCx = OCxREF + Polarity, OCx_EN = 1$ |

*Note:* The state of the external I /O pins connected to the standard OCx channels is determined by the OCx channel state and the GPIO and AFIO registers.

# 10.2.4.10 Counter (TMRx\_CNT)

Address offset: 0x24

Reset value: 0x0000

| Bit       | Name       | Туре | Description                                          |
|-----------|------------|------|------------------------------------------------------|
|           |            |      | Counter value                                        |
| Bit 31:16 | CNT[31:16] | rw   | When TMR2 or TMR5 enables plus mode (The PMEN bit in |
|           |            |      | the TMR_CTRL1 register), CNT is expanded to 32 bits. |
| Bit 15:0  | CNT[15:0]  | rw   | Counter value                                        |

# 10.2.4.11 Prescaler (TMRx\_DIV)

Address offset: 0x28

Reset value: 0x0000

| Bit      | Name      | Туре | Description                                           |
|----------|-----------|------|-------------------------------------------------------|
|          |           |      | Prescaler value                                       |
|          |           |      | The counter clock frequency CK_CNT is                 |
| Bit 15:0 | DIV[15:0] | rw   | fCK_DIV/(DIV[15:0]+1).                                |
|          |           |      | DIV contains the value loaded in the active prescaler |
|          |           |      | register at each update event                         |

# 10.2.4.12 Auto-reload Register (TMRx\_AR)

Address offset: 0x2C



| Bit       | Name      | Туре | Description                                                                                                                                                                                                                                            |
|-----------|-----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | AR[31:16] | rw   | Auto-reload value<br>When TMR2 or TMR5 enables plus mode (The PMEN bit in<br>the TMR_CTRL1 register), AR is expanded to 32 bits.                                                                                                                       |
| Bit 15:0  | AR[15:0]  | rw   | Auto-reload value<br>AR contains the value to be loaded to the actual auto-reload<br>register. When auto-reload value is null, the counter does<br>not work.<br>Please refer to <u>Section 10.2.3.1</u> for more details on AR<br>update and behavior. |

# 10.2.4.13 Capture/Compare Register 1 (TMRx\_CC1)

Address offset: 0x34

| Bit       | Name       | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | CC1[31:16] | rw   | Capture/Compare 1 value<br>When TMR2 or TMR5 enables plus mode (The PMEN bit in<br>the TMR_CTRL1 register), CC1 is expanded to 32 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 15:0  | CC1[15:0]  | rw   | Capture/Compare 1 value<br>If CC1 channel is configured as output:<br>CC1 is the value to be loaded in the actual capture/compare<br>1 register (preload value). The written value is loaded<br>immediately to the active register if the preload feature is<br>not selected in the TMRx_CCM1 register (the OC1PEN bit).<br>Else, the preload value is loaded in the active<br>capture/compare 1 register when an update event occurs.<br>The active capture/compare register involves in the<br>comparison with the counter TMRx_CNT, and generates the<br>output on OC1.<br>If CC1 channel is configured as input: |



|  | CC1 is the counter value transferred by the last input |
|--|--------------------------------------------------------|
|  | capture 1 event (IC1).                                 |

# 10.2.4.14 Capture/Compare Register 2 (TMRx\_CC2)

Address offset: 0x38

Reset value: 0x0000

| Bit       | Name       | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | CC2[31:16] | rw   | Capture/Compare 2 value<br>When TMR2 or TMR5 enables plus mode (The PMEN bit in<br>the TMR_CTRL1 register), CC2 is expanded to 32 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 15:0  | CC2[15:0]  | rw   | Capture/Compare 2 value<br>If CC2 channel is configured as output:<br>CC2 is the value to be loaded in the actual capture/compare<br>2 register (preload value). The written value is loaded<br>immediately to the active register if the preload feature is<br>not selected in the TMRx_CCM2 register (the OC2PEN bit).<br>Else the preload value is loaded in the active<br>capture/compare 2 register when an update event occurs.<br>The active capture/compare register involves in the<br>comparison with the counter TMRx_CNT, and generates<br>output on OC2.<br>If CC2 channel is configured as input:<br>CC2 is the counter value transferred by the last input<br>capture 2 event (IC2). |

# 10.2.4.15 Capture/Compare Register 3 (TMRx\_CC3)

Address offset: 0x3C

| Bit       | Name       | Туре | Description             |
|-----------|------------|------|-------------------------|
| Bit 31:16 | CC3[31:16] | rw   | Capture/Compare 3 value |



|          |           |    | When TMP2 or TMPE anables plus made (The PMEN bit in         |
|----------|-----------|----|--------------------------------------------------------------|
|          |           |    | When TMR2 or TMR5 enables plus mode (The PMEN bit in         |
|          |           |    | the TMR_CTRL1 register), CC3 is expanded to 32 bits.         |
|          |           |    | Capture/Compare 3 value                                      |
|          |           |    | If CC3 channel is configured as output:                      |
|          |           |    | CC3 is the value to be loaded in the actual capture/compare  |
|          |           |    | 3 register (preload value). The written value is loaded      |
|          |           |    | immediately to the active register if the preload feature is |
|          |           |    | not selected in the TMRx_CCM3 register (the OC3PEN bit).     |
| Bit 15:0 |           |    | Else the preload value is loaded in the active               |
| DIC 15.0 | CC3[15:0] | rw | capture/compare 3 register when an update event occurs.      |
|          |           |    | The active capture/compare register involves in the          |
|          |           |    | comparison with the counter TMRx_CNT, and generates          |
|          |           |    | output on OC3.                                               |
|          |           |    | If CC3 channel is configured as input:                       |
|          |           |    | CC3 is the counter value transferred by the last input       |
|          |           |    | capture 3 event (IC3).                                       |

# 10.2.4.16 Capture/Compare Register 4 (TMRx\_CC4)

Address offset: 0x40

Reset value: 0x0000

Mango

| Bit       | Name       | Туре | Description                                                                                                                                                                                                                                                                                                                                                                |
|-----------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | CC4[31:16] | rw   | Capture/Compare 4 value<br>When TMR2 or TMR5 enables plus mode (The PMEN bit in<br>the TMR_CTRL1 register, CC4 is expanded to 32 bits.                                                                                                                                                                                                                                     |
| Bit 15:0  | CC4[15:0]  | rw   | Capture/Compare 4 value<br>If CC4 channel is configured as output:<br>CC4 is the value to be loaded in the actual capture/compare<br>4 register (preload value). The written value is loaded<br>immediately to the active register if the preload feature is<br>not selected in the TMRx_CCM4 register (the OC4PEN bit).<br>Else the preload value is loaded in the active |

Hangzhou Vango Technologies, Inc.

|  | capture/compare 4 register when an update event occurs. |
|--|---------------------------------------------------------|
|  | The active capture/compare register involves in the     |
|  | comparison with the counter TMRx_CNT, and generates     |
|  | output on OC4.                                          |
|  | If CC4 channel is configured as input:                  |
|  | CC4 is the counter value transferred by the last input  |
|  | capture 4 event (IC4).                                  |

# **10.2.4.17 DMA Control Register (TMRx\_DMAC)**

Address offset: 0x48

| Bit       | Name       | Туре | Description                                                   |
|-----------|------------|------|---------------------------------------------------------------|
| Bit 15:13 | -          | -    | Reserved. Always read as 0.                                   |
| Bit 12:8  | DBLEN[4:0] | rw   | DMA burst length                                              |
|           |            |      | The bits define the number of DMA transfers in burst mode     |
|           |            |      | (the timer recognizes a burst transfer when a read or a write |
|           |            |      | access is done to the TMRx_DMABA address). Namely,            |
|           |            |      | defining the byte number of transfer.                         |
|           |            |      | 00000: 1 byte                                                 |
|           |            |      | 00001: 2 bytes                                                |
|           |            |      | 00010: 3 bytes                                                |
|           |            |      |                                                               |
|           |            |      | 10001: 18 bytes                                               |
| Bit 7:5   | -          | -    | Reserved. Always read as 0.                                   |
| Bit 4:0   | ADDR[4:0]  | rw   | DMA base address                                              |
|           |            |      | The bits define the base address for DMA transfers in burst   |
|           |            |      | mode (when read/write access is done to the TMRx_DMABA        |
|           |            |      | register). ADDR is defined as an offset starting from the     |
|           |            |      | address of the TMRx_CTRL1 register.                           |
|           |            |      | 00000: TMRx_CTRL1,                                            |
|           |            |      | 00001: TMRx_CTRL2,                                            |



| 00010: TMRx_SMC |
|-----------------|
|-----------------|

.....

# 10.2.4.18 DMA Address in Burst Mode (TMRx\_DMABA)

Address offset: 0x4C

Reset value: 0x0000

| Bit                  | Name | Туре                                                         | Description                                               |
|----------------------|------|--------------------------------------------------------------|-----------------------------------------------------------|
| Bit 15:0 DMABA[15:0] |      |                                                              | DMA register for burst accesses                           |
|                      |      |                                                              | A read or write to the TMRx_DMABA register accesses the   |
|                      |      |                                                              | register located at the following address:                |
|                      | rw   | TMRx_CTRL1 address + ADDR + DMA index, where:                |                                                           |
|                      |      | TMRx_CTRL1 address is the address of the control register    |                                                           |
|                      |      | $1(TMRx\_CTRL1)$ . "ADDR" is the base address defined in the |                                                           |
|                      |      |                                                              | TMRx_DMAC register.                                       |
|                      |      | "DMA index" is the offset automatically controlled by the    |                                                           |
|                      |      |                                                              | DMA, and is determined by the DBLEN bit configured in the |
|                      |      |                                                              | TMRx_DMAC register.                                       |

# **10.3 General-purpose Timer (TMR9 to TMR14)**

# **10.3.1 TMRx Introduction**

The general-purpose timers consist of a 16-bit auto-reload counter driven by a programmable prescaler.

They may be used for a variety of purposes, including measuring the pulse lengths of input signals (input capture) or generating output waveforms (output compare and PWM).

Pulse lengths and waveform periods can be modulated from a few microseconds to several milliseconds using the timer prescaler and the RCC clock controller prescalers.

The timers are completely independent, and they do not share any resources and can be synchronized. Please refer to <u>Section 10.3.3.12</u>.



# **10.3.2 TMRx Main Function**

# 10.3.2.1 TMR9 and TMR12 Main Function

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

• 16-bit up auto-reload counter

• 16-bit programmable prescaler (can be modified on the fly) used to divide the counter clock frequency by any factor between  $1 \sim 65536$ 

- 2 independent channels:
  - Input capture
  - Output compare
  - PWM generation (Edge-aligned mode)
  - One-pulse mode output
- Timers and the interconnected synchronization circuit are controlled by external signals.
- Interrupt generation at the following events:
  - Update: Counter overflow, counter initialization (by software or internal trigger)
  - Trigger event (counter starts, stops, initialized, or counts by internal trigger)
  - Input capture
  - Output compare

Figure 10-57 Block Diagram of General-purpose Timer TMR9/12





Reg Note: transfers the contents in the preload registers to active registers on U event according to the control bits.

- Event
- Interrupt

#### TMR10, TMR11, TMR13, and TMR14 Main Function 10.3.2.2

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

- 16-bit up auto-reload counter
- 16-bit programmable prescaler (can be modified on the fly) used to divide the counter clock frequency by any factor between 1 ~ 65536
- 1 independent channel:
  - Input capture
  - Output compare
  - PWM generation (Edge-aligned mode)
  - One-pulse mode output
- Interrupt generation at the following events:
  - Update: Counter overflow, counter initialization (by software or internal trigger)
  - Input capture
  - Output compare

Figure 10-58 Block Diagram of General-purpose Timers TMR10/11/13/14





Note:

transfers the contents in the preload registers to active registers on U event according to the control bits.



Event Interrupt output

# **10.3.3 TMRx Function Overview**

### 10.3.3.1 Time-base Unit

This programmable general-purpose timer mainly consists of a 16-bit counter and relevant auto-reload registers. The counter can count up. The counter clock is obtained through a prescaler.

The counter, the auto-reload register, and the prescaler register can be written or read by software. This is true even when the counter is running.

The time-base unit includes:

- Counter register (TMRx\_CNT)
- Prescaler register (TMRx\_DIV)
- Auto-reload register (TMRx\_AR)

The auto-reload register is preloaded. Each read or write to the auto-reload register will access the preload register. The contents written to the preload register are transferred into its shadow register immediately or at each update event (UEV) according to the auto-reload preload enable bit (ARPEN) in the TMRx\_CTRL1 register. When the UEVDIS bit in the TMRx\_CTRL1 register is '0', update events will be generated once the counter reaches the overflow value. Update events can also be generated by software.



Please refer to the following sections for the detailed introduction on generation of the update events under different configurations.

The counter is driven by the prescaler clock output, CK\_CNT, and it is enabled when the counter enable bit (CNTEN) in the TMRx\_CTRL1 register is set. (Please refer to the controller slave mode descriptions for more details on counter enable.)

Note: The actual counter enable signal, CNT\_EN, is set 1 clock cycle after CNTEN is set..

#### Prescaler

The prescaler can divide the counter clock frequency by any factor between  $1 \sim 65536$ , and this is achieved with a 16-bit counter controlled by a 16-bit register (in the TMRx\_DIV register). Its value can be changed on the fly since the control register is buffered. The new prescaler ratio takes effect at the next update event.

Figure 10-59 and Figure 10-60 are examples of on-the-fly prescaler ratio change.

Figure 10-59 Counter Timing Diagram with Prescaler Division Changing from 1 to 2



Figure 10-60 Counter Timing Diagram with Prescaler Division Changing from 1  $\sim$  4



| CK_DIV                                     |                                              |                                |                 |
|--------------------------------------------|----------------------------------------------|--------------------------------|-----------------|
| CEN                                        |                                              |                                |                 |
| Timer clock = CK_CNT                       |                                              |                                |                 |
| Counter register                           | F7 K F8 K F9 K FA K FB K FC                  | 00                             | ( <u>01</u> )   |
| Update event<br>(UEV)<br>Prescaler control |                                              | 3                              |                 |
| register                                   | Write new values to the<br>TMRx_DIV register |                                |                 |
| Prescaler buffer                           | 0                                            | 3                              |                 |
| Prescaler counter                          | 0                                            | $0 \times 1 \times 2 \times 3$ | 0 X 1 X 2 X 3 X |

# 10.3.3.2 Counter Mode

#### Upcounting mode

In upcounting mode, the counter counts from 0 to the auto-reload value (content of the TMRx\_AR counter), and restarts from 0 and generates a counter overflow event.

An update event can be generated at each counter overflow; setting the UEVG bit in the TMRx\_EVEG register (by software, for TMR9 and 12, even by the slave mode controller) also generates the update events.

Update events can be disabled by setting the UEVDIS bit in the TMRx\_CTRL1 register. This avoids changing the shadow registers while writing new values to the preload registers. No update event occurs until the UEVDIS bit is cleared. However, when the update events are generated, the counter and the prescaler are still cleared (but the prescaler ratio does not change). In addition, if the UEVRS (update request selection) bit in the TMRx\_CTRL1 register is set, setting the UEVG bit generates an update event UEV, but the UEVIF flag is not set by hardware (that is, no interrupt is sent). This can avoid update and capture interrupt generation when the counter is cleared in capture mode.

When an update event occurs, all the registers are updated, and the update flag (the UEVIF bit in the TMRx\_STS register) is set by hardware (according to the UEVRS bit).

- The buffer of the prescaler is reloaded with the preload value (content of the TMRx\_DIV register).
- The auto-reload shadow register is updated with the preload value (TMRx\_AR).

Figure 10-61 ~ Figure 10-66 show the examples of the counter behaviors for different clock frequencies



when  $TMRx_AR = 0x36$ :

Figure 10-61 Counter Timing Diagram with Internal Clock Divided by 1



#### Figure 10-62 Counter Timing Diagram with Internal Clock Divided by 2



#### Figure 10-63 Counter Timing Diagram with Internal Clock Divided by 4

| CK_INT                           |           |                   |
|----------------------------------|-----------|-------------------|
| CNT_EN                           |           |                   |
| Timer clock = CK_CNT             | ∏         |                   |
| Counter register                 | 0035 X 00 | 036 X 0000 X 0001 |
| Counter overflow                 |           |                   |
| Update event<br>(UEV)            |           |                   |
| Update interrupt flag<br>(UEVIF) |           |                   |







Figure 10-65 Counter Timing Diagram with Update Event When ARPEN = 0 (TMRx\_AR Not Preloaded)



Figure 10-66 Counter Timing Diagram with Update Event When ARPEN = 1 (TMRx\_AR is Preloaded)



| CK_DIV                         |                                   |                                         |
|--------------------------------|-----------------------------------|-----------------------------------------|
| CNT_EN                         |                                   |                                         |
| Timer clock = CK_CNT           |                                   |                                         |
| Counter reigster               | F0 X F1 X F2 X F3 X F4 X F5       | 00 X 01 X 02 X 03 X 04 X 05 X 06 X 07 X |
| Counter overflow               |                                   | Γ                                       |
| Update event<br>(UEV)          |                                   | Γ                                       |
| Update interrupt flag (UEVI    | -)                                |                                         |
| Auto-reload register           | F5                                | 36                                      |
| Auto-reload shadow<br>register | F5                                | 36                                      |
| Write n                        | ew values to the TMRx_AR register |                                         |

## 10.3.3.3 Clock Selection

The counter clock can be provided by the following clock sources:

- Internal clock (CK\_INT)
- External clock mode 1 (only TMR9 and TMR12): External input pin (TIx)

• Internal trigger input (ITRx) (only TMR9 and TMR12): The trigger signal connected to another timer. For example, users can configure Timer 1 to act as the prescaler for Timer 2. Please refer to <u>Section 10.3.3.12</u>.

#### Internal clock source (CK\_INT)

For TMR10/TMR11 and TMR13/TMR14, internal clock source is the clock source by default.

For TMR9 and TMR12, if the slave mode controller is disabled (SMSEL = 000 in the TMRx\_SMC register), the CNTEN, DIR (in the TMRx\_CTRL1 register), and UEVG bits (in the TMRx\_EVEG register) are the actual control bits, and they can be changed only by software (except for the UEVG bit, which will be cleared automatically). As soon as the CNTEN bit is written '1', the prescaler is clocked by the internal clock, CK\_INT.

Figure 10-67 shows the behavior of the control circuit and the up counter in normal mode, without prescaler.

Figure 10-67 Control Circuit in Normal Mode with Internal Clock Divided by 1



Hangzhou Vango Technologies, Inc.



#### External clock mode 1 (TMR9 and TMR12)

This mode is selected when SMSEL = 111 in the TMRx\_SMC register. The counter can count at each rising or falling edge on a selected input.

Figure 10-68 TI2 External Clock Connection Example



For example, to configure the up counter to count in response to a rising edge on the TI2 input, use the following procedure:

- 1. Configure channel 2 to detect the rising edges on the TI2 input by writing C2SEL = '01' in the TMRx\_CCM1 register.
- Configure the input filter duration by writing the IC2DF[3:0] bits in the TMRx\_CCM1 register (if no filter is needed, keep IC2F = 0000).

Note: The capture prescaler is not used as trigger, so it does not need to be configured.

- 3. Select the rising edge polarity by writing C2P = 0' in the TMRx\_CCE register.
- 4. Select the timer external clock mode 1 by writing SMSEL = 111' in the TMRx\_SMC register.



Hangzhou Vango Technologies, Inc.

5. Select TI2 as the trigger input source by writing TRGSEL = 110' in the TMRx\_SMCregister.

6. Enable the counter by writing CNTEN = 1' in the TMRx\_CTRL1 register.

When a rising edge occurs on TI2, the counter counts once, and the TRGIF flag is set.

The delay between the rising edge on TI2 and the actual clock of the counter depends on the resynchronization circuit on TI2 input.

Figure 10-69 Control Circuit in External Clock Mode 1



### 10.3.3.4 Capture/Compare Channel

Each capture/compare channel is built around a capture/compare register (including a shadow register), also an input stage for capture (digital filter, multiplexing, and prescaler) and an output stage (comparator and output control).

Figure 10-70 ~ Figure 10-72 provide an overview of one capture/compare channel. The input stage samples the corresponding TIx input signal to generate a filtered signal TIxF. Then, an edge detector with polarity selection generates a signal (TIxFPx) which can be the trigger input for the slave mode controller, or be the capture command. This signal enters the capture register through the prescaler.

Figure 10-70 Capture/Compare Channel (e.g. Channel 1 Input Stage)





The output stage generates an intermediate waveform OCxRef (active high) which serves as reference. The polarity of final output signal is determined by the end of the chain.

Figure 10-71 Capture/Compare Channel 1 Main Circuit



Figure 10-72 Capture/Compare Channel Output Stage (Channel 1)





The capture/compare block is made of one preload register and one shadow register. Write and read only access the preload register.

In capture mode, captures are actually done in the shadow register, and then are copied into the preload register.

In compare mode, the content of the preload register is copied into the shadow register, and then the content of the shadow register is compared with the counter.

### 10.3.3.5 Input Capture Mode

In input capture mode, the capture/compare registers (TMRx\_CCx) latch the current counter value after a corresponding edge on the ICx signal is detected. When a capture occurs, the corresponding CxIF flag (TMRx\_STS register) is set. An interrupt or a DMA request can be sent if enabled. If a capture occurs when the CxIF flag is already high, the over-capture flag CxOF (TMRx\_STS register) is set. CxIF can be cleared by writing CxIF = 0 or by reading the captured data stored in the TMRx\_CCx register. CxOF = 0 is cleared when writing CxOF = 0.

The following example shows how to capture the counter value to the TMRx\_CC1 register at TI1 input rising edge:

• Select the active input: Write C1SEL = 01 in the TMRx\_CC1 register since the TMRx\_CC1 register must be linked to the TI1 input. The channel is configured as input as long as the C1SEL is not '00'. The TM1\_CC1 register becomes read-only.

• Program the desired input filter duration according to the input signal (if the input is TIx, the control bit of the input filter is the ICxDF bit in the TMRx\_CCMx register). If the input signal is not stable during five internal clock cycles at most, the filter duration should be configured longer than five clock cycles. Therefore, an actual edged transition on TI1 can be validated by 8

consecutive samples (at  $f_{CK_{INT}}$  frequency). That is, write IC1DF = 0011 in the TMRx\_CCM1 register.

- Select the active transition edge on the TI1 channel by writing C1P = 0 (rising edge) in the TMRx\_CCE register.
- Program the input prescaler. In this example, each valid transition is expected to be captured, so the prescaler is disabled (write IC1DIV = 00 in the TMRx\_CCM1 register).
- Set C1EN = 1 in the TMRx\_CCE register to allow the counter value to be captured into the capture register
- If needed, enable the relevant interrupt request by setting the C1IE bit in the TMRx\_DIE register.

When an input capture occurs:

- The counter value is sent to the TMRx\_CC1 register on active transition.
- C1IF flag is set (interrupt flag). When at least two consecutive captures occur and the C1IF flag is not cleared, C1OF is also set.
- An interrupt is generated if the C1IE bit is set.

• In case of overcapture, it is recommended that the data is read before the overcapture flag. This is to avoid missing an overcapture information that is generated after reading the overcapture flag and before reading the data.

*Note: Input capture interrupt can be generated by setting the corresponding CxG bit in the TMRx\_EVEG register with software.* 

### 10.3.3.6 PWM Input Mode (Only TMR9 and TMR12)

This mode is a special case of input capture mode. The procedure is the same as input capture mode except for the following conditions:

- Two ICx signals are mapped on the same TIx input.
- The two ICx signals are active on edges but with opposite polarities.
- One of the two TIxFP signals is used as trigger input signal and the slave mode controller is configured as reset mode.

For example, if users need to measure the period (TMRx\_CC1 register) and the duty cycle (TMRx\_CC2 register) of the PWM signal input on TI1, the procedure is as follows (depending on CK\_INT frequency and prescaler value):



• Select the active input for TMRx\_CC1: Write C1SEL = 01 in the TMRx\_CCM1, register (TI1 selected).

• Select the active polarity for TI1FP1 (used to capture data into TMRx\_CC1 and clear the counter): Write C1P = 0 (active on rising edge).

• Select the active input for TMRx\_CC2: Write C2SEL = 10 in the TMRx\_CCM1 register (TI1 selected).

• Select the active polarity for TI1FP2 (capture data to TMRx\_CC2): Write C2P = 1 (active on falling edge).

• Select the valid trigger input signal: Write TRGSEL = 101 in the TMRx\_SMC register (TI1FP1 selected).

• Configure the slave mode controller as reset mode: Write SMSEL = 100 in the TMRx\_SMC register.

• Enable the captures: Write C1EN = 1 and C2EN = 1 in the TMRx\_CCE register.

Figure 10-73 PWM Input Mode Timing



Since only TI1FP1 and TI2FP2 are connected to the slave mode controller, the PWM input mode can be used only with the TMRx\_CH1/TMRx\_CH2 signals.

# 10.3.3.7 Forced Output Mode

In output mode (CxSEL = 00 in the TMRx\_CCMx register), output compare signal (OCxREF and the corresponding OCx) can be forced to be active or inactive level directly by software, independent of any comparison between the output compare register and the counter.

To force an output compare signal (OCxREF/OCx) to its active level, users can write the corresponding



OCxMODE = 101 in the TMRx\_CCMx register. In this way, OCxREF is forced high (OCxREF is always active high), and at the same time OCx gets the opposite value of the CxP polarity bit.

For example: CxP = 0 (OCx active high), then OCx is forced to be high level.

The OCxREF signal can be forced low by writing OCxMODE = 100 in the TMRx\_CCx register.

In this mode, the comparison between the TMRx\_CCx shadow register and the counter is still ongoing, and the corresponding flag is also modified. Accordingly, the corresponding interrupt and DMA requests are still generated. This will be described in the "Output Compare Mode" section.

### 10.3.3.8 Output Compare Mode

This function is used to control an output waveform or to indicate that a period of time has elapsed.

When a match is found between the capture/compare register and the counter, the output compare function proceeds as follows:

• Output the value defined by the output compare mode (the OCxMODE bit in the TMRx\_CCMx register) and the output polarity (the CxP bit in the TMRx\_CCE register) to the corresponding pin. When being compared and matched, the output pin can keep its level (OCxMODE = 000), be set active (OCxMODE = 001), be set inactive (OCxMODE = 010), or toggle (OCxMODE = 011).

- Set the flag bit in the interrupt status register (the CxIF bit in the TMRx\_STS register).
- An interrupt will be generated if the corresponding interrupt mask is set (the CxIE bit in the TMRx\_DIE register).

The OCxPEN bit in the TMRx\_CCMx register can be configured to choose whether the TMRx\_CCx register uses the preload register.

In output compare mode, the update event UEV has no effect on OCxREF and OCx output.

The timing resolution can reach one count of the counter. Output compare mode can also be used to output a single pulse (in one-pulse mode).

Output compare mode configuration procedure is as follows:

1. Select the counter clock (internal, external, and prescaler).

- 2. Write the corresponding data to the TMRx\_AR and the TMRx\_CCx registers.
- 3. Set the CxIE and/or CxDE bits if an interrupt and/or DMA request is to be generated.

4. Select the output mode. For example, when the counter CNT and the CCx bit are matched, toggle theHangzhou Vango Technologies, Inc.317 / 782

output pin of OCx, CCx preload is not disabled, and the OCx output is enabled with active high, users must configure OCxMODE = '011', OCxPEN = '0', CxP = '0', and CxEN = '1'.

5. Enable the counter by setting the CNTEN bit in the TMRx\_CTRL1 register.

The TMRx\_CCx register can be updated at any time by software to control the output waveform, under the condition that the preload register is not enabled (OCxPEN = 0', else the TMRx\_CCx shadow register can only be updated at the next update event). An example is shown in Figure 10-74.

Figure 10-74 Output Compare Mode, Toggle on OC1



### 10.3.3.9 PWM Mode

Pulse width modulation mode can generate a signal with its frequency determined by the TMRx\_AR register and its duty cycle determined by TMRx\_CCx register.

Writing '110' (PWM mode 1) or '111' (PWM mode 2) in the OCxMODE bit in the TMRx\_CCMx register can independently configure each OCx output channel and generate single-channel PWM. The OCxPEN bit in the TMRx\_CCMx register must be configured to enable the corresponding preload register. Finally, the ARPEN bit in the TMRx\_CTRL1 register (in upcounting or center-aligned modes) must be set to enable the auto-reload preload register.

Since the preload registers are transferred to the shadow registers only when an update event occurs, before starting the counter, users must initialize all the registers by setting the UEVG bit in the TMRx\_EVEG register. OCx polarity is software programmable by setting the CxP bit in the TMRx\_CCE register. It can be programmed as active high or active low. OCx output enable is controlled by the CxEN bit in the TMRx\_CCE register. Please refer to the description of TMRx\_CCE register for more details.

In PWM mode (1 or 2), TMRx\_CNT and TMRx\_CCx are always compared to confirm that TMRx\_CCx



 $\leq$  TMRx\_CNT or TMRx\_CNT  $\leq$  TMRx\_CCx.

In edge-aligned mode, timers generate PWM only when the counter counts up.

#### **PWM edge-aligned mode**

The following is an example of PWM mode 1. The reference PWM signal, OCxREF, is high once TMRx\_CNT < TMRx\_CCx; else, it becomes low. If the compare value in TMRx\_CCx is greater than the auto-reload value (in TMRx\_AR), OCxREF is held at '1'.

If the compare value is 0, then OCxREF is held at '0'. Figure 10-75 shows an example of edge-aligned PWM waveforms with TMRx\_AR = 8.

Figure 10-75 Edge-aligned PWM Waveforms (AR = 8)



### 10.3.3.10 One-pulse Mode

One-pulse mode (OPM) is quite different from the above-mentioned modes. It allows the counter to respond to a stimulus and to generate a pulse with a programmable length after a programmable delay.

The counter can be enabled through the slave mode controller, generating waveforms in output compare mode or PWM mode. One-pulse mode is selected by setting the OPMODE bit in the TMRx\_CTRL1 register, and this can stop the counter automatically at the next update event UEV.

A pulse can be generated only if the compare value is different from the initial counter value. Before enabling (when the timer is waiting for the trigger), the following configuration must be done:

 $CNT < CCx \le AR$  (especially, 0 < CCx)



Figure 10-76 Example of One-pulse Mode



For example, if users want to generate a positive pulse with a length of tPULSE on OC1 once a rising edge is detected on the TI2 input pin and after a delay tDELAY.

If TI2FP2 is used as trigger 1:

• Map TI2FP2 to TI2 by writing C2SEL = '01' in the TMRx\_CCM1 register.

• Write C2P = '0' in the TMRx\_CCE register to enable TI2FP2 to detect a rising edge.

• Write TRGSEL = `110' in the TMRx\_SMC register to make TI2FP2 to be the trigger of the slave mode controller (TRGI).

• Write SMSEL = '110' in the TMRx\_SMC register (trigger mode), and TI2FP2 is used to enable the counter.

The OPM waveform is defined by the value written to the compare registers (the clock frequency and the counter prescaler should be taken into account).

•  $t_{DELAY}$  is defined by the value written to the TMRx\_CC1 register.

•  $t_{PULSE}$  is defined by the comparison result of auto-reload value and the compare value (TMRx\_AR - TMRx\_CC1).

• Assume that users want to generate a waveform with a transition from '0' to '1' when a compare match occurs, and a transition from '1' to '0' when the counter reaches the preload value. First, set OC1MODE = '111' in the TMRx\_CCM1 register to enter PWM mode 2. Enable the desired preload registers by setting OC1PEN = '1' in the TMRx\_CCM1 register and the ARPEN bit in the TMRx\_CTRL1 register. Afterwards, write compare value in the TMRx\_CC1 register, write auto-reload value in the TMRx\_AR register, modify the UEVG bit to generate an update event, and wait for an external trigger event on TI2. In this example, C1P = '0'.



In this example, since only one pulse is needed, '1' must be written to the OPMODE bit in the TMRx\_CTRL1 register to stop the counter at the next update event (when the counter rolls over to 0 from the auto-reload value).

When OPMODE = 0', exit one-pulse mode.

#### Special case: OCx fast enable

In one-pulse mode, the counter is enabled by setting the CNTEN bit on the edge detection logic of TIx input pin. Then, the comparison between the counter and the compare value makes output toggle. However, since several clock cycles are needed for these operations, it limits the minimum delay  $t_{DELAY}$  that users can get.

The OCxFEN bit in the TMRx\_CCMx register can be set to output a waveform with the minimum delay. In this case, OCxREF (and OCx) are forced to respond to the stimulus, instead of relying on the comparison result. The waveform outputted is the same as the one being compared and matched. OCxFEN acts only if the channel is configured as PWM1 or PWM2 mode.

### 10.3.3.11 Timer and External Trigger Synchronization

The TMRx timer can be synchronized with an external trigger in several modes: reset mode, gated mode, and trigger mode.

#### Slave mode: Reset mode

The counter and its prescaler can be reinitialized when a trigger input event occurs. In this case, if the UEVRS bit of the TMRx\_CTRL1 register is low, an update event UEV is generated. Then, all the preloaded registers (TMRx\_AR, TMRx\_CCx) will be updated.

In the following example, the up counter is cleared due to a rising edge on TI1 input:

• Configure channel 1 to detect the rising edges on TI1. Configure the input filter duration (in this example, no filter is needed, so keep IC1DF = 0000). The capture prescaler is not used for triggering, so it does not need to be configured. The C1SEL bit selects the input capture source only, that is, C1SEL = 01 in the TMRx\_CCM1 register. Write C1P = 0 in the TMRx\_CCE register to confirm the polarity (and detect rising edges only).

• Configure the timer as reset mode by writing SMSEL = 100 in the TMRx\_SMC register. Select TI1 as the input source by writing TRGSEL = 101 in the TMRx\_SMC register.

• Start the counter by writing CNTEN = 1 in the TMRx\_CTRL1 register.

Hangzhou Vango Technologies, Inc.

The counter starts counting on the internal clock, and runs normally until TI1 rising edge occurs; at this time, the counter is cleared and restarts from 0. In the meantime, the trigger flag (the TRGIF bit in the TMRx\_STS register) is set, and an interrupt request can be sent depending on the configuration of the TRGIE bit in the TMRx\_DIE register (interrupt enable). Figure 10-77 shows the behavior when the auto-reload register TMRx\_AR = 0x36. The delay between the rising edge on TI1 and the actual reset of the counter is determined by the resynchronization circuit on TI1input.

Figure 10-77 Control Circuit in Reset Mode



#### Slave mode: Gated mode

The counter can be enabled according to the selected level of input.

In the following example, the counter counts up only when TI1 input is low:

• Configure channel 1 to detect low levels on TI1. Configure the input filter duration (in this example, no filter is needed, so keep IC1DF = 0000). The capture prescaler is not used for triggering, so it does not need to be configured. The C1SEL bits select the input capture source. Set C1SEL = 01 in the TMRx\_CCM1 register. Write C1P = 1 in the TMRx\_CCE register to confirm the polarity (and detect low level only).

• Configure the timer as gated mode by writing SMSEL = 101 in the TMRx\_SMC register. Select TI1 as the input source by writing TRGSEL = 101 in the TMRx\_SMC register.

• Enable the counter by writing CNTEN = 1 in the TMRx\_CTRL1 register. In gated mode, the counter cannot be enabled if CNTEN = 0, no matter what the trigger input level is.

The counter starts counting on the internal clock as long as TI1 is low, and stops as soon as TI1 becomes high. The TRGIF flag in the TMRx\_STS register is set both when the counter starts and stops.

The delay between the rising edge on TI1 and the actual stop of the counter is determined by the



resynchronization circuit on TI1 input.





#### Slave mode: Trigger mode

The counter can be enabled according to the selected level of input.

In the following example, the counter starts to count up at rising edge on TI2 input:

• Configure channel 2 to detect the rising edge on TI2. Configure the input filter duration (in this example, no filter is needed, so keep IC2DF = 0000). The capture prescaler is not used for triggering, so it does not need to be configured. The C2SEL bits are only used to select the input capture source. Set C2SEL = 01 in the TMRx\_CCM1 register. Write C2P = 1 in the TMRx\_CCE register to confirm the polarity (and detect low level only).

• Configure the timer as trigger mode by writing SMSEL = 110 in the TMRx\_SMC register. Select TI2 as the input source by writing TRGSEL = 110 in the TMRx\_SMC register.

The counter starts counting on the internal clock as long as a rising edge occurs on TI2, and at the same time the TRGIF flag is set.

The delay between the rising edge on TI2 and enabling counting is determined by the resynchronization circuit on TI2 input.

Figure 10-79 Control Circuit in Trigger Mode



| TI2                             |    |             |
|---------------------------------|----|-------------|
| CNT_EN                          |    |             |
| CNT_EN                          |    |             |
| Counter clock = CK_CNT = CK_DIV |    |             |
|                                 |    |             |
| Counter register                | 34 | 35/36/37/38 |
| TRGIF                           |    |             |

### 10.3.3.12 Timer Synchronization

All TMRx timers are linked together internally for timer synchronization or chaining. Please refer to <u>Section 10.2.3.15</u> for more details.

Note: Before receiving the master t imer trigger signal, slave timer clock should be enabled first. When receiving trigger from master timer, do not change it while running.

## 10.3.3.13 Debug Mode

When the microcontroller enters debug mode (Cortex<sup>®</sup>-M4F core halted), the TMRx counter either continues to work normally or stops, depending on DBG\_TMRx\_STOP configuration in DBG module. For more details, please refer to <u>Section 20.2.2</u>.

# 10.3.4 TMR9 and TMR12 Register Description

# 10.3.4.1 Control Register 1 (TMRx\_CTRL1)

Address offset: 0x00

| Bit                 | Name | Туре                                                         | Description                 |
|---------------------|------|--------------------------------------------------------------|-----------------------------|
| Bit 15:10           | -    | -                                                            | Reserved. Always read as 0. |
| Bit 9:8 CLKDIV[1:0] |      |                                                              | Clock division              |
|                     | rw   | Define the division ratio between the timer clock (CK_INT)   |                             |
|                     |      | frequency and sampling frequency used by the digital filters |                             |
|                     |      | (ETR, TIx).                                                  |                             |



|         |        |    | 00: $t_{DTS} = t_{CK\_INT}$                                         |
|---------|--------|----|---------------------------------------------------------------------|
|         |        |    | 01: $t_{DTS} = 2 \times t_{CK\_INT}$                                |
|         |        |    | 10: $t_{DTS} = 4 \times t_{CK\_INT}$                                |
|         |        |    | 11: Reserved                                                        |
|         |        |    | Auto-reload preload enable                                          |
| Bit 7   | ARPEN  | rw | 0: TMRx_AR register is not buffered.                                |
|         |        |    | 1: TMRx_AR register is buffered.                                    |
| Bit 6:4 | -      | -  | Reserved. Always read as 0.                                         |
|         |        |    | One pulse mode                                                      |
| Bit 3   | 004005 |    | 0: The counter does not stop at update event.                       |
|         | OPMODE | rw | 1: The counter stops at the next update event (the CNTEN bit is     |
|         |        |    | cleared).                                                           |
|         |        |    | Update request source                                               |
|         |        |    | This bit is set and cleared by software to select the UEV event     |
|         |        |    | sources.                                                            |
|         |        |    | 0: Any of the following events generates an update interrupt if     |
| Bit 2   | UEVRS  | rw | update interrupt request is enabled:                                |
|         |        |    | - Counter overflow                                                  |
|         |        |    | - Setting the UEVG bit                                              |
|         |        |    | 1: Only counter overflow generates an update interrupt t if         |
|         |        |    | update interrupt is enabled.                                        |
|         |        |    | Update disable                                                      |
|         |        |    | This bit is set and cleared by software to enable/disable UEV       |
|         |        |    | event generation.                                                   |
|         |        |    | 0: UEV is enabled. An update event (UEV) is generated by any of     |
|         |        |    | the following events:                                               |
| Bit 1   | UEVDIS | rw | - Counter overflow                                                  |
|         |        |    | - Setting the UEVG bit                                              |
|         |        |    | 1: UEV is disabled. Update events are not generated, and shadow     |
|         |        |    | registers (AR, DIV, and CCx) keep their values. The counter and     |
|         |        |    | the prescaler are reinitialized if the UEVG bit is set or the slave |



|       |       |    | mode controller sends a hardware reset.                                                                                                                      |
|-------|-------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 0 | CNTEN | rw | Counter enable 0: The counter is disabled. 1: The counter is<br>enabled.<br>CNTEN is cleared automatically in one-pulse mode when an<br>update event occurs. |

#### 10.3.4.2 Slave Mode Control Register (TMRx\_SMC)

Address offset: 0x08

| Bit      | Name        | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:7 | -           | -    | Reserved. Always read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 6:4  | TRGSEL[2:0] | rw   | Trigger selection<br>The bits select the trigger input used to synchronize the counter.<br>000: Internal trigger 0 (ITR0)<br>001: Internal trigger 1 (ITR1)<br>010: Internal trigger 2 (ITR2)<br>011: Internal trigger 3 (ITR3)<br>100: TI1 edge detector (TI1F_ED)<br>101: Filtered timer input 1 (TI1FP1)<br>110: Filtered timer input 2 (TI2FP2)<br>111: Reserved<br>Please refer to Table 10-4 for the details on ITRx for each timer.<br><i>Note: These bits must be changed only when they are not used</i><br>(e.g. when SMSEL = 000) to avoid wrong edge detections at<br>transitions. |
| Bit 3    | -           | -    | Reserved. Always read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 2:0  | SMSEL[2:0]  | rw   | Slave mode selection<br>When external signals are selected, the active edge of the<br>trigger signal (TRGI) is relevant to the selected external input<br>polarity (Please refer to input control register and control                                                                                                                                                                                                                                                                                                                                                                         |



|  | register description.)                                              |
|--|---------------------------------------------------------------------|
|  | 000: Slave mode is disabled - If $CNTEN = 1$ , the prescaler is     |
|  | clocked directly by the internal clock.                             |
|  | 001: Reserved                                                       |
|  | 010: Reserved                                                       |
|  | 011: Reserved                                                       |
|  | 100: Reset Mode - Rising edge of the selected trigger input         |
|  | (TRGI) reinitializes the counter and generates an update            |
|  | register signal.                                                    |
|  | 101: Gated Mode - The counter clock is enabled when the trigger     |
|  | input (TRGI) is high. The counter stops (but is not reset) once     |
|  | the trigger becomes low. Both start and stop of the counter are     |
|  | controlled.                                                         |
|  | 110: Trigger Mode - The counter starts at a rising edge of the      |
|  | trigger input TRGI (but it is not reset). Only the start of the     |
|  | counter is controlled.                                              |
|  | 111: External Clock Mode 1 - Rising edges of the selected trigger   |
|  | input (TRGI) clocks the counter.                                    |
|  | Note 1: The gated mode must not be used if TI1F_EN is selected      |
|  | as the trigger input (TRGSEL = 100). This is because TI1F_ED        |
|  | outputs 1 pulse for each transition on TI1F, whereas the gated      |
|  | mode checks the level of the trigger input signal.                  |
|  | Note 2: Before receiving the master timer trigger signal, slave     |
|  | timer clock should be enabled first. While receiving trigger signal |
|  | from master timer, do not change slave timer clock.                 |

#### Table 10-4 TMRx Internal Trigger Connection(Note)

| Slave | ITR0 (TRGSEL = | ITR1 (TRGSEL = | ITR2 (TRGSEL = | ITR3 (TRGSEL = |
|-------|----------------|----------------|----------------|----------------|
| Timer | 000)           | 001)           | 010)           | 011)           |
| TMR9  | TMR2_TRGO      | TMR3_TRGO      | TMR10_OC       | TMR11_OC       |
| TMR12 | TMR4_TRGO      | TMR5_TRGO      | TMR13_OC       | TMR14_OC       |

Note: When a corresponding timer is not present in the product, the corresponding trigger ITRx is



not available.

## **10.3.4.3 DMA/Interrupt Enable Register (TMRx\_DIE)**

Address offset: 0x0C Reset value: 0x0000

| Bit      | Name  | Туре | Description                                 |
|----------|-------|------|---------------------------------------------|
| Bit 15:7 | -     | -    | Reserved. Always read as 0.                 |
| Bit 6    | TRGIE | rw   | Trigger interrupt enable                    |
|          |       |      | 0: Trigger interrupt is disabled.           |
|          |       |      | 1: Trigger interrupt is enabled.            |
| Bit 5:3  | -     | -    | Reserved. Always read as 0.                 |
| Bit 2    | C2IE  | rw   | Capture/Compare 2 interrupt enable          |
|          |       |      | 0: Capture/Compare 2 interrupt is disabled. |
|          |       |      | 1: Capture/Compare 2 interrupt is enabled.  |
| Bit 1    | C1IE  | rw   | Capture/Compare 1 interrupt enable          |
|          |       |      | 0: Capture/Compare 1 interrupt is disabled. |
|          |       |      | 1: Capture/Compare 1 interrupt is enabled.  |
| Bit 0    | UEVIE | rw   | Update interrupt enable                     |
|          |       |      | 0: Update interrupt is disabled.            |
|          |       |      | 1: Update interrupt is enabled.             |

#### **10.3.4.4** Status Register (TMRx\_STS)

Address offset: 0x10

| Bit       | Name | Туре | Description                                                          |
|-----------|------|------|----------------------------------------------------------------------|
| Bit 15:11 | -    | -    | Reserved. Always read as 0.                                          |
| Bit 10    | C2OF | rw   | Capture/Compare 2 overcapture flag Please refer to C1OF description. |



| 1       |       | T  |                                                                                                                                                                 |
|---------|-------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |       |    | Capture/Compare 1 overcapture flag<br>This flag is set by hardware only when the corresponding<br>channel is configured as input capture mode. It is cleared by |
| Bit 9   | C1OF  | rw | writing `0'.                                                                                                                                                    |
|         |       |    | 0: No overcapture is detected.                                                                                                                                  |
|         |       |    | 1: When the counter value is captured to the TMRx_CC1                                                                                                           |
|         |       |    | register, C1IF flag is already set.                                                                                                                             |
| Bit 8:7 | -     | -  | Reserved. Always read as 0.                                                                                                                                     |
|         |       |    | Trigger interrupt flag                                                                                                                                          |
|         |       |    | This flag is set by hardware at trigger event (When the slave                                                                                                   |
|         |       |    | mode controller is in all modes except for gated mode, active                                                                                                   |
| Bit 6   | TRGIF | rw | edge is detected on TRGI input, or any edge in the gated mode).                                                                                                 |
|         |       |    | It is cleared by software.                                                                                                                                      |
|         |       |    | 0: No trigger event occurs.                                                                                                                                     |
|         |       |    | 1: Trigger interrupt is pending.                                                                                                                                |
| Bit 5:3 | -     | -  | Reserved. Always read as 0.                                                                                                                                     |
| Bit 2   | C2IF  | rw | Capture/Compare 2 interrupt flag Please refer to C1IF                                                                                                           |
|         |       |    | description.                                                                                                                                                    |
|         |       |    | Capture/Compare 1 interrupt flag                                                                                                                                |
|         |       |    | If channel CC1 is configured as output mode:                                                                                                                    |
|         |       |    | This flag is set by hardware when the counter value matches the                                                                                                 |
|         |       |    | compare value, but not in center-aligned mode (Please refer to                                                                                                  |
|         |       |    | the CMSEL bits in the TMRx_CTRL1 register). It is cleared by                                                                                                    |
| Dit 1   |       |    | software.                                                                                                                                                       |
| Bit 1   | C1IF  | rw | When the TMRx_CC1 value is higher than TMRx_AR, the CC1F bit                                                                                                    |
|         |       |    | is set high after counter overflow.                                                                                                                             |
|         |       |    | 0: No match                                                                                                                                                     |
|         |       |    | 1: The TMRx_CNT value matches the TMRx_CC1 value.<br>If channel CC1 is configured as input mode:                                                                |
|         |       |    | This bit is set by hardware on a capture. It is cleared by                                                                                                      |
|         |       |    | software or by reading the TMRx_CC1 register.                                                                                                                   |
|         |       |    | Soliware of by reading the HMRX_CCT register.                                                                                                                   |



|       |       | 1  |                                                                             |
|-------|-------|----|-----------------------------------------------------------------------------|
|       |       |    | 0: No input capture occurs.                                                 |
|       |       |    | 1: The counter value is captured to the TMRx_CC1 register (An               |
|       |       |    | edge which matches the selected polarity is detected on IC1).               |
|       |       |    | Update interrupt flag                                                       |
|       |       |    | This bit is set by hardware on an update event. It is cleared by            |
|       |       |    | software.                                                                   |
|       |       |    | 0: No update event occurs.                                                  |
|       |       |    | 1: Update interrupt is pending. This bit is set by hardware when            |
|       |       |    | the registers are updated:                                                  |
| Bit 0 | UEVIF | rw | <ul> <li>If UEVDIS = 0 and UEVRS = 0 in the TMRx_CTRL1 register,</li> </ul> |
|       |       |    | an update event is generated when UEVG = 1 in the TMRx_EVEG                 |
|       |       |    | register (the counter CNT is reinitialized by software).                    |
|       |       |    | <ul> <li>If UEVDIS = 0 and UEVRS = 0 in the TMRx_CTRL1 register,</li> </ul> |
|       |       |    | an update event is generated when the counter CNT is                        |
|       |       |    | reinitialized by trigger events.                                            |
|       |       |    | This bit is set at counter overflow when UEVDIS = $0$                       |

## 10.3.4.5 Event Generation Register (TMRx\_EVEG)

Address offset: 0x14

| Bit      | Name  | Туре | Description                                                    |
|----------|-------|------|----------------------------------------------------------------|
| Bit 15:7 | -     | -    | Reserved. Always read as 0.                                    |
|          |       |      | Trigger generation                                             |
|          |       |      | This bit is set by software to generate a trigger event. It is |
| Bit 6    | 70.00 | rw   | cleared automatically by hardware.                             |
| DIL O    | TRGG  |      | 0: No action                                                   |
|          |       |      | 1: TRGIF = 1 in the TMRx_STS register, the corresponding       |
|          |       |      | interrupt is generated if enabled.                             |
| Bit 5:3  | -     | -    | Reserved. Always read as 0.                                    |
| Bit 2    | C2G   | rw   | Capture/compare 2 generation Please refer to C1G description.  |



|       |      |    | Capture/compare 1 generation                                        |
|-------|------|----|---------------------------------------------------------------------|
|       |      |    | This bit is set by software to generate a capture/compare event.    |
|       |      |    | It is cleared automatically by hardware.                            |
|       |      |    | 0: No action                                                        |
|       |      |    | 1: A capture/compare event is generated on channel CC1:             |
| Bit 1 |      |    | If channel CC1 is configured as output:                             |
|       | C1G  | rw | Set C1IF = 1. The corresponding interrupt request is generated      |
|       |      |    | if enabled.                                                         |
|       |      |    | If channel CC1 is configured as input:                              |
|       |      |    | The current value of the counter is captured to the TMRx_CC1        |
|       |      |    | register. Set C1IF = 1. The corresponding interrupt request is      |
|       |      |    | generated if enabled. If C1IF is already $1'$ , set C1OF = 1.       |
|       |      |    | Update generation                                                   |
|       |      | rw | This bit can be set by software, and it is automatically cleared    |
|       |      |    | by hardware.                                                        |
| Bit 0 | UEVG |    | 0: No action                                                        |
|       |      |    | 1: Re-initialize the counter and generate an update. Please note    |
|       |      |    | that the prescaler counter is also cleared, but the prescaler ratio |
|       |      |    | is not affected. The counter is cleared.                            |
|       |      |    |                                                                     |

#### 10.3.4.6 Capture/Compare Mode Register 1 (TMRx\_CCM1)

Address offset: 0x18

#### Reset value: 0x0000

The channels can be used in input (capture mode) or in output (compare mode). The direction of a channel is defined by the corresponding CxSEL bits. All the other bits of this register have different functions in input and output modes. For a given bit, OCxx describes its function when the channel is in output mode, ICxx describes its function when the channel is in input mode. Attention must be given to the fact that the same bit can have different definitions for the input stage and for the output stage.

#### Output compare mode:

| Bit | Name | Туре | Description |
|-----|------|------|-------------|
|-----|------|------|-------------|



| Bit 15           | -                 | -  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------|-------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 14:12        | OC2MODE[2:0       | rw | Output compare 2 mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 11           | OC2PEN            | rw | Output compare 2 preload enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 10           | OC2FEN            | rw | Output compare 2 fast enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  |                   |    | Capture/Compare 2 selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                  |                   |    | This bit defines the channel direction (input/output) and the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  |                   |    | selection of input pin:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                  |                   |    | 00: CC2 channel is configured as output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                  |                   |    | 01: CC2 channel is configured as input, IC2 is mapped on TI2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 9:8          | C2SEL[1:0]        | rw | 10: CC2 channel is configured as input, IC2 is mapped on TI1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  |                   |    | 11: CC2 channel is configured as input, IC2 is mapped on TRC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  |                   |    | This mode works only when the internal trigger input is selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                  |                   |    | (by the TRGSEL bit in the TMRx_SMC register).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  |                   |    | Note: C2SEL can be written only when the channel is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  |                   |    | (C2EN = `0' in the TMRx_CCE register).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                  |                   |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 7            | -                 | -  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 7            | -                 | -  | Reserved.<br>Output compare 1 enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 7            | -                 | -  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 7            | -                 | -  | Output compare 1 enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 7            | -                 | -  | Output compare 1 enable<br>The bits define the behavior of the output reference signal,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 7            | -                 | _  | Output compare 1 enable<br>The bits define the behavior of the output reference signal,<br>OC1REF, and OC1REF determines the OC1 value. OC1REF is                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 7            | -                 | -  | Output compare 1 enable<br>The bits define the behavior of the output reference signal,<br>OC1REF, and OC1REF determines the OC1 value. OC1REF is<br>active high, while the active level of OC1 is determined by the                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 7            | -                 | _  | Output compare 1 enable<br>The bits define the behavior of the output reference signal,<br>OC1REF, and OC1REF determines the OC1 value. OC1REF is<br>active high, while the active level of OC1 is determined by the<br>C1P bit.                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 7<br>Bit 6:4 | -<br>OC1MODE[2:0] | rw | Output compare 1 enable<br>The bits define the behavior of the output reference signal,<br>OC1REF, and OC1REF determines the OC1 value. OC1REF is<br>active high, while the active level of OC1 is determined by the<br>C1P bit.<br>000: Frozen. The comparison between the output compare                                                                                                                                                                                                                                                                                                                    |
|                  | -<br>OC1MODE[2:0] | rw | Output compare 1 enable<br>The bits define the behavior of the output reference signal,<br>OC1REF, and OC1REF determines the OC1 value. OC1REF is<br>active high, while the active level of OC1 is determined by the<br>C1P bit.<br>000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect on                                                                                                                                                                                                                                                     |
|                  | -<br>OC1MODE[2:0] | rw | Output compare 1 enable<br>The bits define the behavior of the output reference signal,<br>OC1REF, and OC1REF determines the OC1 value. OC1REF is<br>active high, while the active level of OC1 is determined by the<br>C1P bit.<br>000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect on<br>OC1REF.                                                                                                                                                                                                                                          |
|                  | -<br>OC1MODE[2:0] | rw | Output compare 1 enable<br>The bits define the behavior of the output reference signal,<br>OC1REF, and OC1REF determines the OC1 value. OC1REF is<br>active high, while the active level of OC1 is determined by the<br>C1P bit.<br>000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect on<br>OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is forced                                                                                                                                                                         |
|                  | -<br>OC1MODE[2:0] | rw | Output compare 1 enable<br>The bits define the behavior of the output reference signal,<br>OC1REF, and OC1REF determines the OC1 value. OC1REF is<br>active high, while the active level of OC1 is determined by the<br>C1P bit.<br>000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect on<br>OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is forced<br>high when the value of the counter TMRx_CNT matches the                                                                                                              |
|                  | -<br>OC1MODE[2:0] | rw | Output compare 1 enable<br>The bits define the behavior of the output reference signal,<br>OC1REF, and OC1REF determines the OC1 value. OC1REF is<br>active high, while the active level of OC1 is determined by the<br>C1P bit.<br>000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect on<br>OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is forced<br>high when the value of the counter TMRx_CNT matches the<br>capture/compare register 1 (TMRx_CC1).                                                                    |
|                  | -<br>OC1MODE[2:0] | rw | Output compare 1 enable<br>The bits define the behavior of the output reference signal,<br>OC1REF, and OC1REF determines the OC1 value. OC1REF is<br>active high, while the active level of OC1 is determined by the<br>C1P bit.<br>000: Frozen. The comparison between the output compare<br>register TMRx_CC1 and the counter TMRx_CNT has no effect on<br>OC1REF.<br>001: Set channel 1 to active level on match. OC1REF is forced<br>high when the value of the counter TMRx_CNT matches the<br>capture/compare register 1 (TMRx_CC1).<br>010: Set channel 1 to inactive level on match. OC1REF is forced |



| Man     | ao         | Hang | zhou Vango Technologies, Inc. 333 / 78                                     |
|---------|------------|------|----------------------------------------------------------------------------|
| Bit 1:0 | C1SEL[1:0] | rw   | Capture/Compare 1 selection                                                |
|         |            |      | mode.                                                                      |
|         |            |      | This bit only acts when channel is configured as PWM1or PWM2               |
|         |            |      | cycles.                                                                    |
|         |            |      | trigger input and to activate CC1 output is reduced to 3 clock             |
|         |            |      | irrelevant to the result of the comparison. Delay to sample the            |
|         |            |      | match. Therefore, OC is set to the compare level which is                  |
| Bit 2   | OC1FEN     | rw   | 1: An active edge on the trigger input acts like a compare                 |
|         |            |      | trigger input, the minimum delay to activate CC1 output is 5 clock cycles. |
|         |            |      | when the trigger is ON. When an active edge occurs on the                  |
|         |            |      | 0: CC1 behaves normally with the counter and CC1 values eve                |
|         |            |      | the input event.                                                           |
|         |            |      | This bit is used to accelerate the CC output's response to trigge          |
|         |            |      | Output compare 1 fast enable                                               |
|         |            |      | TMRx_CTRL1 register). Else, the behavior is not guaranteed.                |
|         |            |      | register only in one-pulse mode (OPMODE = '1' in th                        |
|         |            |      | Note: The PWM mode can be used without validating the preloa               |
|         |            |      | value is sent to the active register at each update event.                 |
| Bit 3   | OC1PEN     | rw   | operations only access the preload register. TMRx_CC1 preloa               |
|         |            |      | 1: Preload function of TMRx_CC1 is enabled. Read/Wri                       |
|         |            |      | written at any time, and the new value takes effect immediatel             |
|         |            |      | 0: Preload function of TMRx_CC1 is disabled. TMRx_CC1 can b                |
|         |            |      | Output compare 1 preload enable                                            |
|         |            |      | compare mode switches from frozen mode to PWM mode .                       |
|         |            |      | only when the comparison result changes or when output                     |
|         |            |      | Note: In PWM mode 1 or PWM mode 2, OC1REF level change                     |
|         |            |      | inactive once TMRx_CNT < TMRx_CC1, else active.                            |
|         |            |      | TMRx_CC1, else inactive. 111: PWM mode2-Channel 1 is                       |
|         |            |      | 110: PWM mode1—Channel 1 is active once TMRx_CNT <                         |
|         |            |      | 101: Force active level. OC1REF is forced high.                            |
|         |            |      | TMRx_CNT. 100: Force inactive level. OC1REF is forced low.                 |

|  | The bits define the channel direction (input/output), and input  |
|--|------------------------------------------------------------------|
|  | pin selection:                                                   |
|  | 00: CC1 channel is configured as output.                         |
|  | 01: CC1 channel is configured as input, IC1 is mapped on TI1.    |
|  | 10: CC1 channel is configured as input, IC1 is mapped on TI2.    |
|  | 11: CC1 channel is configured as input, IC1 is mapped on TRC.    |
|  | This mode works only when the internal trigger input is selected |
|  | (by the TRGSEL bit in the TMRx_SMC register).                    |
|  | Note: C1SEL can be written only when the channel is disabled     |
|  | (C1EN = '0' in the TMRx_CCE register).                           |

#### Input capture mode:

| Bit       | Name        | Туре | Description                                                            |
|-----------|-------------|------|------------------------------------------------------------------------|
| Bit 15:12 | IC2DF[3:0]  | rw   | Input capture 2 filter                                                 |
| Bit 11:10 | IC2DIV[1:0] | rw   | Input capture 2 prescaler                                              |
| Bit 9:8   | C2SEL[1:0]  | rw   | Capture/compare 2 selection                                            |
|           |             |      | The bits define the channel direction (input/output), and input        |
|           |             |      | pin selection:                                                         |
|           |             |      | 00: CC2 channel is configured as output.                               |
|           |             |      | 01: CC2 channel is configured as input, IC2 is mapped on TI2.          |
|           |             |      | 10: CC2 channel is configured as input, IC2 is mapped on TI1.          |
|           |             |      | 11: CC2 channel is configured as input, IC2 is mapped on TRC.          |
|           |             |      | This mode works only when the internal trigger input is selected       |
|           |             |      | (by the TRGSEL bit in the TMRx_SMC register).                          |
|           |             |      | Note: C2SEL can be written only when the channel is disabled           |
|           |             |      | (C2EN = '0' in the TMRx_CCE register).                                 |
| Bit 7:4   | IC1DF[3:0]  | rw   | Input capture 1 filter                                                 |
|           |             |      | The bits define the frequency used to sample TI1 input and the         |
|           |             |      | length of digital filter. The digital filter is an event counter which |
|           |             |      | records N consecutive events that are needed to generate a             |
|           |             |      | transition on the output:                                              |
|           |             |      | 0000: No filter, sampling is done at fors                              |



|         |             |    | 0001: $f_{\text{SAMPLING}} = f_{\text{CK}_{\text{INT}}}$ , N = 2   |
|---------|-------------|----|--------------------------------------------------------------------|
|         |             |    | 0010: $f_{\text{SAMPLING}} = f_{\text{CK}_{\text{INT}}}$ , $N = 4$ |
|         |             |    | 0011: $f_{\text{SAMPLING}} = f_{CK_{\text{INT}}}$ , N = 8          |
|         |             |    | 0100: $f_{SAMPLING} = f_{DTS}/2, N = 6$                            |
|         |             |    | 0101: $f_{SAMPLING} = f_{DTS}/2$ , N = 8                           |
|         |             |    | 0110: $f_{SAMPLING} = f_{DTS}/4$ , N = 6                           |
|         |             |    | 0111: $f_{SAMPLING} = f_{DTS}/4$ , N = 8                           |
|         |             |    | 1000: $f_{SAMPLING} = f_{DTS}/8$ , N = 6                           |
|         |             |    | 1001: f <sub>SAMPLING</sub> = f <sub>DTS</sub> /8, N = 8           |
|         |             |    | 1010: $f_{SAMPLING} = f_{DTS}/16$ , N = 5                          |
|         |             |    | 1011: $f_{SAMPLING} = f_{DTS}/16$ , N = 6                          |
|         |             |    | 1100:f <sub>SAMPLING</sub> = f <sub>DTS</sub> /16, N = 8           |
|         |             |    | 1101: $f_{\text{SAMPLING}} = f_{\text{DTS}}/32$ , N = 5            |
|         |             |    | 1110: $f_{SAMPLING} = f_{DTS}/32, N = 6$                           |
|         |             |    | 1111: fsampling = fdts/32, N = 8                                   |
| Bit 3:2 | IC1DIV[1:0] | rw | Input capture 1 prescaler                                          |
|         |             |    | The bits define CC1 input (IC1) prescaler ratio.                   |
|         |             |    | Once C1EN = $0'$ (in the TMRx_CCE register), the prescaler is      |
|         |             |    | reset.                                                             |
|         |             |    | 00: No prescaler. Capture is done each time when an edge is        |
|         |             |    | detected on the capture input.                                     |
|         |             |    | 01: Capture is done once every 2 events.                           |
|         |             |    | 10: Capture is done once every 4 events                            |
|         |             |    | 11: Capture is done once every 8 events.                           |
| Bit 1:0 | C1SEL[1:0]  | rw | Capture/Compare 1 selection                                        |
|         |             |    | The bits define the channel direction (input/output), and input    |
|         |             |    | pin selection:                                                     |
|         |             |    | 00: CC1 channel is configured as output.                           |
|         |             |    | 01: CC1 channel is configured as input, IC1 is mapped on TI1.      |
|         |             |    | 10: CC1 channel is configured as input, IC1 is mapped on TI2.      |
|         |             |    | 11: CC1 channel is configured as input, IC1 is mapped on TRC.      |
|         |             |    | This mode works only when the internal trigger input is selected   |
|         |             |    | zhou Vango Technologies, Inc. 335 / 782                            |

|  | (by the TRGSEL bit in the TMRx_SMC register).                |
|--|--------------------------------------------------------------|
|  | Note: C1SEL can be written only when the channel is disabled |
|  | (C1EN = '0' in the TMRx_CCE register).                       |
|  |                                                              |
|  |                                                              |

## **10.3.4.7** Capture/Compare Enable Register (TMRx\_CCE)

Address offset: 0x20 Reset value: 0x0000

| Bit 15:8<br>Bit 7<br>Bit 6 | -<br>C2NP<br>- | -<br>rw | Reserved. Always read as 0.<br>Capture/Compare 2 output polarity Please refer to C1NP                                                                                                                                                                              |
|----------------------------|----------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            |                | rw      |                                                                                                                                                                                                                                                                    |
| Bit 6                      | -              |         | description.                                                                                                                                                                                                                                                       |
|                            |                | -       | Reserved. Always read as 0.                                                                                                                                                                                                                                        |
| Bit 5                      | C2P            | rw      | Capture/Compare 2 output polarity Please refer to C1P description.                                                                                                                                                                                                 |
| Bit 4                      | C2EN           | rw      | Capture/Compare 2 output enable Please refer to C1EN description.                                                                                                                                                                                                  |
| Bit 3                      | C1NP           | rw      | Capture/Compare 1 complementary output polarity<br>CC1 channel is configured as output: C1NP should be kept<br>cleared.<br>CC1 channel is configured as input: C1NP is combined with C1P<br>to define TI1FP1/TI2FP1 polarity (Please refer to C1P<br>description). |
| Bit 2                      | -              | -       | Reserved. Always read as 0.                                                                                                                                                                                                                                        |
| Bit 1                      | C1P            | rw      | Capture/Compare 1 output polarity<br>CC1 channel is configured as output:<br>0: OC1 is active high.<br>1: OC1 is active low.<br>CC1 channel is configured as input:<br>The CC1NP/CC1P bits select the polarity signal of TI1FP1 and                                |



|       |      |    | TI2FP1 as trigger or capture signal.                                |
|-------|------|----|---------------------------------------------------------------------|
|       |      |    | 00: Not inverted/Rising edge. Circuit is sensitive to TIxFP1 rising |
|       |      |    | edge (capture, reset in trigger, external clock, or trigger mode).  |
|       |      |    | TIxFP1 is not inverted (gated mode in trigger).                     |
|       |      |    | 01: Inverted/Falling edge. Circuit is sensitive to TIxFP1 falling   |
|       |      |    | edge (capture, reset in trigger, external clock, or trigger mode).  |
|       |      |    | TIxFP1 is inverted (gated mode in trigger).                         |
|       |      |    | 10: Reserved                                                        |
|       |      |    | 11: Not inverted/Both edges. Circuit is sensitive to both TIxFP1    |
|       |      |    | rising and falling edge (capture, reset in trigger, external clock, |
|       |      |    | or trigger mode). TIxFP1 is not inverted (gated mode in trigger).   |
|       |      |    | Capture/Compare 1 output enable                                     |
|       | C1EN | rw | CC1 channel is configured as output:                                |
|       |      |    | 0: OFF— OC1 output is disabled.                                     |
|       |      |    | 1: ON $-$ OC1 is outputted on the corresponding output pin.         |
| Bit 0 |      |    | CC1 channel is configured as input:                                 |
|       |      |    | This bit determines whether the counter value can be captured       |
|       |      |    | to the TMRx_CC1 register.                                           |
|       |      |    | 0: Capture is disabled.                                             |
|       |      |    | 1: Capture is enabled.                                              |

#### Table 10-5 Standard OCx Channel Output Control Bit

| CxEN Bit | OCx Output State                      |
|----------|---------------------------------------|
| 0        | Output disabled (OCx = 0, OCx_EN = 0) |
| 1        | $OCx = OCxREF + Polarity, OCx_EN = 1$ |

Note: The state of the external I/O pins connected to the standard OCx channels is determined by the OCx channel state and the GPIO and AFIO registers.

#### 10.3.4.8 Counter (TMRx\_CNT)

Address offset: 0x24



| Bit      | Name      | Туре | Description   |
|----------|-----------|------|---------------|
| Bit 15:0 | CNT[15:0] | rw   | Counter value |

## **10.3.4.9** Prescaler (TMRx\_DIV)

Address offset: 0x28

Reset value: 0x0000

| Bit      | Name      | Туре | Description                                                                                                                                                                      |
|----------|-----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | DIV[15:0] | rw   | Prescaler value<br>The counter clock frequency CK_CNT is $f_{CK_DIV}/(DIV[15:0]+1)$ .<br>DIV contains the value loaded in the active prescaler register at<br>each update event. |

#### 10.3.4.10 Auto-reload Register (TMRx\_AR)

Address offset: 0x2C

Reset value: 0x0000

| Bit      | Name     | Туре | Description                                                        |
|----------|----------|------|--------------------------------------------------------------------|
|          |          |      | Auto-reload value                                                  |
|          |          |      | AR contains the value to be loaded to the actual auto-reload       |
|          | AR[15:0] | rw   | register.                                                          |
| Bit 15:0 |          |      | Please refer to Section 10.3.3.1 for more details on AR update and |
|          |          |      | behavior. When auto-reload value is null, the counter does not     |
|          |          |      | work.                                                              |

## 10.3.4.11 Capture/Compare Register 1 (TMRx\_CC1)

Address offset: 0x34

| Bit         | Name      | Туре | Description                                                        |           |
|-------------|-----------|------|--------------------------------------------------------------------|-----------|
| Bit 15:0    | CC1[15:0] | rw   | Capture/Compare 1 value<br>If CC1 channel is configured as output: |           |
| Hango Hangz |           |      | zhou Vango Technologies, Inc.                                      | 338 / 782 |

|  | CC1 is the value to be loaded in the actual capture/compare 1    |
|--|------------------------------------------------------------------|
|  | register (preload value). The written value is loaded            |
|  | immediately to the active register if the preload feature is not |
|  | selected in the TMRx_CCM1 register (the OC1PEN bit). Else, the   |
|  | preload value is loaded in the active capture/compare 1 register |
|  | when an update event occurs.                                     |
|  | The active capture/compare register involves in the comparison   |
|  | with the counter TMRx_CNT, and generates the output on OC1.      |
|  | If CC1 channel is configured as input:                           |
|  | CC1 is the counter value transferred by the last input capture 1 |
|  | event (IC1).                                                     |

## 10.3.4.12 Capture/Compare Register 2 (TMRx\_CC2)

Address offset: 0x38

| Bit      | Name      | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------|-----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | CC2[15:0] | rw   | Capture/Compare 2 value<br>If CC2 channel is configured as output:<br>CC2 is the value to be loaded in the actual capture/compare 2<br>register (preload value). The written value is loaded<br>immediately to the active register if the preload feature is not<br>selected in the TMRx_CCM2 register (the OC2PEN bit). Else the<br>preload value is loaded in the active capture/compare 2 register<br>when an update event occurs.<br>The active capture/compare register involves in the comparison<br>with the counter TMRx_CNT, and generates output on OC2.<br>If CC2 channel is configured as input:<br>CC2 is the counter value transferred by the last input capture 2<br>event (IC2). |



# 10.3.5 TMR10, TMR11, TMR13, and TMR14 Registers Description

## 10.3.5.1 Control Register 1 (TMRx\_CTRL1)

Address offset: 0x00

| Bit       | Name        | Туре | Description                                                     |
|-----------|-------------|------|-----------------------------------------------------------------|
| Bit 15:10 | -           | -    | Reserved. Always read as 0.                                     |
|           |             |      | Clock division                                                  |
|           |             |      | Define the division ratio between the timer clock (CK_INT)      |
|           |             |      | frequency and sampling frequency used by the digital filters    |
| Bit 9:8   | CLKDIV[1:0] | rw   | (ETR, TIx).                                                     |
|           |             | 1 00 | 00: <sub>fdts</sub> = t <sub>ck_int</sub>                       |
|           |             |      | 01: $f_{DTS}$ = 2 x t <sub>CK_INT</sub>                         |
|           |             |      | 10: $f_{DTS}$ = 4 x $t_{CK_{INT}}$                              |
|           |             |      | 11: Reserved                                                    |
|           |             |      | Auto-reload preload enable                                      |
| Bit 7     | ARPEN       | rw   | 0: TMRx_AR register is not buffered.                            |
|           |             |      | 1: TMRx_AR register is buffered.                                |
| Bit 6:3   | -           | -    | Reserved. Always read as 0.                                     |
|           |             |      | Update request source                                           |
|           |             | rw   | This bit is set and cleared by software to select the UEV event |
|           |             |      | sources.                                                        |
|           |             |      | 0: Any of the following events generates an update interrupt    |
| Bit 2     | UEVRS       |      | request if update interrupt is enabled:                         |
|           |             |      | - Counter overflow                                              |
|           |             |      | - Setting the UEVG bit                                          |
|           |             |      | 1: Only counter overflow generates an update interrupt request  |
|           |             |      | if update interrupt request is enabled.                         |



| Bit 1 | UEVDIS | rw | Update disable<br>This bit is set and cleared by software to enable/disable UEV<br>event generation.<br>0: UEV is enabled. An update event (UEV) is generated by any of<br>the following events:<br>- Counter overflow<br>- Setting the UEVG bit<br>1: UEV is disabled. Update events are not generated, and shadow<br>registers (AR, DIV, and CCx) keep their values. The counter and<br>the prescaler are reinitialized if the UEVG bit is set or the slave<br>mode controller sends a hardware reset. |
|-------|--------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit O | CNTEN  | rw | Counter enable<br>0: The counter is disabled.<br>1: The counter is enabled.<br>CNTEN is cleared automatically in one-pulse mode when an<br>update event occurs.                                                                                                                                                                                                                                                                                                                                          |

## **10.3.5.2 DMA/Interrupt Enable Register (TMRx\_DIE)**

Address offset: 0x0C

Reset value: 0x0000

| Bit      | Name  | Туре | Description                                                      |
|----------|-------|------|------------------------------------------------------------------|
| Bit 15:2 | -     | -    | Reserved. Always read as 0.                                      |
| Bit 1    | C1IE  | rw   | Capture/Compare 1 interrupt enable                               |
|          |       |      | 0: Capture/Compare 1 interrupt is disabled.                      |
|          |       |      | 1: Capture/Compare 1 interrupt is enabled.                       |
| Bit 0    | UEVIE | rw   | Update interrupt enable                                          |
|          |       |      | 0: Update interrupt is disabled. 1: Update interrupt is enabled. |

#### **10.3.5.3** Status Register (TMRx\_STS)

#### Address offset: 0x10



| Bit       | Name  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:10 | -     | -    | Reserved. Always read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 9     | C10F  | rw   | Capture/Compare 1 overcapture flag<br>This flag is set by hardware only when the corresponding<br>channel is configured as input capture mode. It is cleared by<br>writing '0'.<br>0: No overcapture is detected.<br>1: When the counter value is captured to the TMRx_CC1                                                                                                                                                                                                                                                                                                                                                                  |
|           |       |      | register, C1IF flag is already set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 8:2   | -     | -    | Reserved. Always read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 1     | C1IF  | rw   | Capture/Compare 1 interrupt flag<br>If channel CC1 is configured as output mode:<br>This flag is set by hardware when the counter value matches<br>the compare value. It is cleared by software.<br>0: No match<br>1: The TMRx_CNT value matches the TMRx_CC1 value. C1F is<br>only '1' at counter overflow.<br>If channel CC1 is configured as input mode:<br>This bit is set by hardware on a capture. It is cleared by<br>software or by reading the TMRx_CC1 register.<br>0: No input capture occurs.<br>1: The counter value is captured to the TMRx_CC1 register (An<br>edge which matches the selected polarity is detected on IC1). |
| Bit 0     | UEVIF | rw   | Update interrupt flag<br>This bit is set by hardware on an update event. It is cleared by<br>software.<br>0: No update event occurs.<br>1: Update interrupt is pending. This bit is set by hardware when<br>the registers are updated:<br>- If UEVDIS = 0 and UEVRS = 0 in the TMRx_CTRL1 register,                                                                                                                                                                                                                                                                                                                                         |



| an update event is generated when UEVG = 1 in the       |
|---------------------------------------------------------|
| TMRx_EVEG register (the counter CNT is reinitialized by |
| software).                                              |
| - If UEVDIS = 0 in the TMRx_CTRL1 register, the counter |
| overflows.                                              |

## **10.3.5.4 Event Generation Register (TMRx\_EVEG)**

Address offset: 0x14

| Bit      | Name | Туре | Description                                                         |
|----------|------|------|---------------------------------------------------------------------|
| Bit 15:2 | -    | -    | Reserved. Always read as 0.                                         |
| Bit 1    | C1G  | rw   | Capture/Compare 1 generation                                        |
|          |      |      | This bit is set by software to generate a capture/compare event.    |
|          |      |      | It is cleared automatically by hardware.                            |
|          |      |      | 0: No action                                                        |
|          |      |      | 1: A capture/compare event is generated on channel 1 CC1:           |
|          |      |      | If channel CC1 is configured as output:                             |
|          |      |      | Set C1IF = 1. The corresponding interrupt request is generated      |
|          |      |      | if enabled.                                                         |
|          |      |      | If channel CC1 is configured as input:                              |
|          |      |      | The current value of the counter is captured to the TMRx_CC1        |
|          |      |      | register. Set $C1IF = 1$ . The corresponding interrupt request is   |
|          |      |      | generated if enabled. If C1IF is already $1'$ , set C1OF = 1.       |
| Bit 0    | UEVG | rw   | Update generation                                                   |
|          |      |      | This bit can be set by software, and it is automatically cleared    |
|          |      |      | by hardware.                                                        |
|          |      |      | 0: No action                                                        |
|          |      |      | 1: Re-initialize the counter and generate an update. Please note    |
|          |      |      | that the prescaler counter is also cleared, but the prescaler ratio |
|          |      |      | is not affected.                                                    |



#### 10.3.5.5 Capture/Compare Mode Register 1 (TMRx\_CCM1)

Address offset: 0x18

Reset value: 0x0000

The channels can be used in input (capture mode) or in output (compare mode). The direction of a channel is defined by the corresponding CxSEL bits. All the other bits of this register have different functions in input and output modes. For a given bit, OCx describes its function when the channel is in output mode, ICx describes its function when the channel is in input mode. Attention must be given to the fact that the same bit can have different definitions for the input stage and for the output stage.

#### Output compare mode:

| Bit      | Name         | Туре | Description                                                                       |
|----------|--------------|------|-----------------------------------------------------------------------------------|
| Bit 15:7 | -            | -    | Reserved. Always read as 0.                                                       |
|          |              |      | Output compare 1 enable                                                           |
|          |              |      | The bits define the behavior of the output reference signal,                      |
|          |              |      | OC1REF, and OC1REF determines the OC1 value. OC1REF is                            |
|          |              |      | active high, while the active level of OC1 is determined by the                   |
|          |              |      | C1P bit.                                                                          |
|          |              |      | 000: Frozen. The comparison between the output compare                            |
|          |              |      | register TMRx_CC1 and the counter TMRx_CNT has no effect on                       |
|          |              |      | OC1REF.                                                                           |
|          |              |      | 001: Set channel 1 to active level on match. OC1REF is forced                     |
| Bit 6:4  | OC1MODE[2:0] | rw   | high when the value of the counter TMRx_CNT matches the                           |
|          |              |      | capture/compare register1 (TMRx_CC1).                                             |
|          |              |      | 010: Set channel 1 to inactive level on match. OC1REF is forced                   |
|          |              |      | low when the value of the counter TMRx_CNT matches the                            |
|          |              |      | capture/compare register1 (TMRx_CC1).                                             |
|          |              |      | 011: Toggle. Toggle OC1REF level whenTMRx_CC1 =                                   |
|          |              |      | TMRx_CNT. 100: Force inactive level. OC1REF is forced low.                        |
|          |              |      | 101: Force active level. OC1REF is forced high.                                   |
|          |              |      | 110: PWM mode1—Once TMRx_CNT <tmrx_cc1, 1="" channel="" is<="" td=""></tmrx_cc1,> |
| Allh     |              |      | active, else inactive. 111: PWM mode2-Once                                        |



|         |            | 1  |                                                                                         |
|---------|------------|----|-----------------------------------------------------------------------------------------|
|         |            |    | TMRx_CNT <tmrx_cc1, 1="" active.<="" channel="" else="" inactive,="" td=""></tmrx_cc1,> |
|         |            |    | Note: In PWM mode 1 or PWM mode 2, OC1REF level changes                                 |
|         |            |    | only when the comparison result changes or when output                                  |
|         |            |    | compare mode switches from frozen mode to PWM mode .                                    |
|         |            |    | Output compare 1 preload enable                                                         |
|         |            |    | 0: Preload function of TMRx_CC1 is disabled. TMRx_CC1 can be                            |
|         |            |    | written at any time, and the new value takes effect                                     |
|         |            |    | immediately.                                                                            |
| Bit 3   |            | -  | 1: Preload function of TMRx_CC1 is enabled. Read/Write                                  |
|         | OC1PEN     | rw | operations only access the preload register. TMRx_CC1 preload                           |
|         |            |    | value is sent to the active register at each update event.                              |
|         |            |    | Note: The PWM mode can be used without validating the preload                           |
|         |            |    | register only in one-pulse mode (OPMODE = `1' in the                                    |
|         |            |    | TMRx_CTRL1 register). Else, the behavior is not guaranteed.                             |
|         |            |    | Output compare 1 fast enable                                                            |
|         | OC1FEN     | rw | This bit is used to accelerate the CC output's response to trigger                      |
|         |            |    | the input event.                                                                        |
|         |            |    | 0: CC1 behaves normally with the counter and CC1 values even                            |
|         |            |    | when the trigger is ON. When an active edge occurs on the                               |
|         |            |    | trigger input, the minimum delay to activate CC1 output is 5                            |
| Bit 2   |            |    | clock cycles.                                                                           |
|         |            |    | 1: An active edge on the trigger input acts like a compare match.                       |
|         |            |    | Therefore, OC is set to the compare level which is irrelevant to                        |
|         |            |    | the result of the comparison. Delay to sample the trigger input                         |
|         |            |    | and to activate CC1 output is reduced to 3 clock cycles.                                |
|         |            |    | This bit only acts when channel is configured as PWM1or PWM2                            |
|         |            |    | mode.                                                                                   |
|         |            |    | Capture/Compare 1 selection                                                             |
|         | C1SEL[1:0] | rw | The bits define the channel direction (input/output), and input                         |
| Bit 1:0 |            |    | pin selection:                                                                          |
|         |            |    | 00: CC1 channel is configured as output.                                                |
|         |            |    | 01: CC1 channel is configured as input, IC1 is mapped on TI1.                           |
|         |            |    | zhou Vango Technologies, Inc. 345 / 782                                                 |

Hangzhou Vango Technologies, Inc.

|  | 10: Reserved                                                 |
|--|--------------------------------------------------------------|
|  | 11: Reserved                                                 |
|  | Note: C1SEL can be written only when the channel is disabled |
|  | (C1EN = '0' in the TMRx_CCE register).                       |

#### Input capture mode:

| Bit      | Name        | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:8 | -           | -    | Reserved. Always read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 7:4  | IC1DF[3:0]  | rw   | Input capture 1 filter<br>The bits define the frequency used to sample TI1 input and the<br>length of digital filter. The digital filter is an event counter which<br>records N consecutive events that are needed to generate a<br>transition on the output:<br>0000: No filter, sampling is done at f <sub>DTS</sub><br>0001: fsampLing= fcK_INT, N = 2<br>0010: fsampLing= fcK_INT, N = 4<br>0011: fsampLing= fcK_INT, N = 8<br>0100: fsampLing = foTs/2, N = 6<br>0101: fsampLing = foTs/2, N = 6<br>0101: fsampLing = foTs/2, N = 8<br>0110: fsampLing = foTs/4, N = 8<br>1000: fsampLing = foTs/4, N = 8<br>1000: fsampLing = foTs/8, N = 6<br>1001: fsampLing = foTs/16, N = 5<br>1011: fsampLing = foTs/16, N = 5<br>1011: fsampLing = foTs/16, N = 8<br>1100: fsampLing = foTs/16, N = 8<br>1101: fsampLing = foTs/32, N = 6<br>1110: fsampLing = foTs/32, N = 6<br>1111: fsampLing = foTs/32, N = 8 |
| Bit 3:2  | IC1DIV[1:0] | rw   | Input capture 1 prescaler<br>The bits define CC1 input (IC1) prescaler ratio.<br>Once C1EN = '0' (in the TMRx_CCE register), the prescaler is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |



|         |            |    | reset.                                                          |
|---------|------------|----|-----------------------------------------------------------------|
|         |            |    | 00: No prescaler. Capture is done each time when an edge is     |
|         |            |    | detected on the capture input.                                  |
|         |            |    | 01: Capture is done once every 2 events.                        |
|         |            |    | 10: Capture is done once every 4 events.                        |
|         |            |    | 11: Capture is done once every 8 events.                        |
|         |            |    | Capture/Compare 1 selection                                     |
|         |            |    | The bits define the channel direction (input/output), and input |
|         |            |    | pin selection:                                                  |
|         |            |    | 00: CC1 channel is configured as output.                        |
| Bit 1:0 | C1SEL[1:0] | rw | 01: CC1 channel is configured as input, IC1 is mapped on TI1.   |
|         |            |    | 10: Reserved                                                    |
|         |            |    | 11: Reserved                                                    |
|         |            |    | Note: C1SEL can be written only when the channel is disabled    |
|         |            |    | (C1EN = '0' in the TMRx_CCE register).                          |

## **10.3.5.6** Capture/Compare Enable Register (TMRx\_CCE)

| Bit      | Name | Туре | Description                                                    |
|----------|------|------|----------------------------------------------------------------|
| Bit 15:4 | -    | -    | Reserved. Always read as 0.                                    |
|          |      |      | Capture/Compare 1 complementary output polarity                |
|          |      |      | CC1 channel is configured as output: C1NP should be kept       |
| Bit 3    | C1NP | rw   | cleared.                                                       |
|          |      |      | CC1 channel is configured as input: C1NP combined with C1P     |
|          |      |      | defines TI1FP1 polarity (Please refer to C1P description).     |
| Bit 3    | -    | -    | Reserved. Always read as 0.                                    |
|          | C1P  | rw   | Capture/Compare 1 output polarity                              |
|          |      |      | CC1 channel is configured as output:                           |
| Bit 1    |      |      | 0: OC1 is active high.                                         |
|          |      |      | 1: OC1 is active low.                                          |
|          |      |      | CC1 channel is configured as input:                            |
|          |      |      | The CC1NP/CC1P bit select TI1FP1 polarity signal as trigger or |

Hangzhou Vango Technologies, Inc.

|       | capture signal.                                                   |
|-------|-------------------------------------------------------------------|
|       | 00: Not inverted/Rising edge. Circuit is sensitive to TIxFP1      |
|       | rising edge (capture mode).                                       |
|       | TIxFP1 is not inverted.                                           |
|       | 01: Inverted/Falling edge. Circuit is sensitive to TIxFP1 falling |
|       | edge (capture mode).                                              |
|       | TIxFP1 is inverted.                                               |
|       | 10: Reserved                                                      |
|       | 11: Not inverted/Both edges. Circuit is sensitive to both TIxFP1  |
|       | rising and falling edge (capture mode). TIxFP1 is not inverted    |
|       | C1EN: Capture/Compare 1 output enable                             |
|       | CC1 channel is configured as output:                              |
|       | 0: OFF— OC1 output is disabled.                                   |
|       | 1: ON $-$ OC1 is outputted on the corresponding output pin.       |
| Bit 0 | CC1 channel is configured as input:                               |
|       | This bit determines whether the counter value can be captured     |
|       | to TMRx_CC1 register.                                             |
|       | 0: Capture is disabled.                                           |
|       | 1: Capture is enabled.                                            |

#### Table 10-6 Standard OCx Channel Output Control Bit

| CxEN Bit | OCx Output State                      |
|----------|---------------------------------------|
| 0        | Output disabled (OCx = 0, OCx_EN = 0) |
| 1        | $OCx = OCxREF + Polarity, OCx_EN = 1$ |

Note: The state of the external I/O pins connected to the standard OCx channels is determined by the OCx channel state and the GPIO and AFIO registers.

## 10.3.5.7 Counter (TMRx\_CNT)

Address offset: 0x24

| Bit  | Name | Туре | Description                   |           |
|------|------|------|-------------------------------|-----------|
| Mang | 70   | Hang | zhou Vango Technologies, Inc. | 348 / 782 |

## 10.3.5.8 Prescaler (TMRx\_DIV)

rw

Address offset: 0x28

Reset value: 0x0000

| Bit      | Name      | Туре | Description                                                       |
|----------|-----------|------|-------------------------------------------------------------------|
|          |           |      | Prescaler value                                                   |
|          |           |      | The counter clock frequency CK_CNT is                             |
| Bit 15:0 | DIV[15:0] | rw   | fCK_DIV/(DIV[15:0]+1).                                            |
|          |           |      | DIV contains the value loaded in the active prescaler register at |
|          |           |      | each update event.                                                |

## 10.3.5.9 Auto-reload Register (TMRx\_AR)

Address offset: 0x2C

Reset value: 0x0000

| Bit      | Name     | Туре | Description                                                  |
|----------|----------|------|--------------------------------------------------------------|
|          |          |      | Auto-reload value                                            |
| Bit 15:0 | AR[15:0] | rw   | AR contains the value to be loaded to the actual auto-reload |
|          |          |      | register.                                                    |

## 10.3.5.10 Capture/Compare Register 1 (TMRx\_CC1)

Address offset: 0x34

| Bit      | Name      | Туре | Description                                                                                                                                                                                                                                                      |
|----------|-----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | CC1[15:0] | rw   | Capture/Compare 1 value<br>If CC1 channel is configured as output:<br>CC1 is the value to be loaded in the actual capture/compare 1<br>register (preload value). The written value is loaded<br>immediately to the active register if the preload feature is not |



|  | selected in the TMRx_CCM1 register (the OC1PEN bit). Else, the   |
|--|------------------------------------------------------------------|
|  | preload value is loaded in the active capture/compare 1 register |
|  | when an update event occurs.                                     |
|  | The active capture/compare register involves in the comparison   |
|  | with the counter, TMRx_CNT, and generates the output on OC1.     |
|  | If CC1 channel is configured as input:                           |
|  | CC1 is the counter value transferred by the last input capture 1 |
|  | event (IC1).                                                     |

## 10.4 Advanced-control Timer (TMR1 and TMR8)

#### 10.4.1 TMR1 and TMR8 Introduction

The advanced-control timer (TMR1 and TMR8) consist of a 16-bit auto-reload counter driven by a programmable prescaler.

They may be used for a variety of purposes, including measuring the pulse lengths of input signals (input capture) or generating output waveforms (output compare, PWM, embedded dead-time, and complementary PWM, and so on).

Pulse lengths and waveform periods can be modulated from a few microseconds to several milliseconds using the timer prescaler and the RCC clock controller prescalers.

The advanced-control timer (TMR1 and TMR8) and general-purpose timers (TMRx) are completely independent, do not share any resources, and can be synchronized. Please refer to <u>Section 10.4.3.20</u>.

## 10.4.2 TMR1 and TMR8 Main Features

The main functions of TMR1 and TMR8 include:

- 16-bit up, down, and up/down auto-reload counter
- 16-bit programmable prescaler (can be modified on the fly) used to divide the counter clock

frequency by any factor between 1 and 65536

- 4 independent channels for:
  - Input capture

ango

- Output compare
- PWM generation (Edge-aligned or center-aligned modes)
- One-pulse mode output
- Complementary outputs with programmable dead-time
- Timers and the interconnected synchronization circuit are controlled by external signals.
- Repetition counter to update the timer registers after a given number of counter cycles
- Break input to put the timer's output signals at reset state or at a known state
- Interrupt/DMA is generated at the following events:

Update: Counter overflow/underflow, counter initialization (by software or internal/external trigger)

- Trigger event (counter starts, stops, initialized, or counts by internal/external trigger)
- Input capture
- Output compare
- Break signal input
- Supports incremental (quadrature) encoder and Hall-sensor circuitry for positioning purposes
- Trigger input for external clock or cycle-by-cycle current management

Figure 10-80 Block Diagram of Advanced-control Timer





control bits.

Interrupt and DMA output

## 10.4.3 TMR1 and TMR8 Function Overview

#### 10.4.3.1 Time-base Unit

This programmable advanced-control timer mainly consists of a 16-bit counter and relevant auto-reload registers. The counter can count up, down, or both up and down. The counter clock is obtained through a prescaler.

The counter, the auto-reload register, and the prescaler register can be written or read by software. This is true even when the counter is running.

The time-base unit includes:

- Counter register (TMRx\_CNT)
- Prescaler register (TMRx\_DIV)
- Auto-reload register (TMRx\_AR)



#### • Repetition counter register (TMRx\_RC)

The auto-reload register is preloaded. Each read or write to the auto-reload register will access the preload register. The contents written to the preload register are transferred into its shadow register immediately or at each update event (UEV) according to the auto-reload preload enable bit (ARPEN) in the TMRx\_CTRL1 register. When the UEVDIS bit in the TMRx\_CTRL1 register is '0', update events will be generated once the counter reaches the overflow value (or underflow when downcounting). Update events can also be generated by software. Please refer to the following sections for the detailed introduction on generation of the update events.

The counter is driven by the prescaler clock output CK\_CNT, and it is enabled when the counter enable bit (CNTEN) in the TMRx\_CTRL1 register is set. (Please refer to the controller slave mode descriptions for more details on counter enable.)

Please note that after the CNTEN bit in the TMRx\_CTRL register is set, the counter starts counting after one clock cycle.

#### Prescaler

The prescaler can divide the counter clock frequency by any factor between 1 and 65536, and this is achieved with a 16-bit counter controlled by a 16-bit register (in the TMRx\_DIV register). Its value can be changed on the fly since the control register is buffered. The new prescaler ratio takes effect at the next update event.

Figure 10-81 and Figure 10-82 are examples of on-the-fly prescaler ratio change.

Figure 10-81 Counter Timing Diagram with Prescaler Division Changing from 1 to 2





Figure 10-82 Counter Timing Diagram with Prescaler Division Changing from 1  $\sim$  4



#### 10.4.3.2 Counter Mode

#### Upcounting mode

In upcounting mode, the counter counts from 0 to the auto-reload value (content of the TMRx\_AR counter), and restarts from 0 and generates a counter overflow event.

If the repetition counter is used, the update event (UEV) is generated after upcounting reaches the programmed count in the repetition counter register (TMRx\_RC). Else, the update event is generated at each counter overflow.



An update event can also be generated by setting the UEVG bit in the TMRx\_EVEG register (by software or by using the slave mode controller).

Update events can be disabled by setting the UEVDIS bit in the TMRx\_CTRL1 register. This avoids changing the shadow registers while writing new values to the preload registers. No update event occurs until the UEVDIS bit is cleared. However, when the update events are generated, the counter and the prescaler are still cleared (but the prescaler ratio does not change). In addition, if the UEVRS (update request selection) bit in the TMRx\_CTRL1 register is set, setting the UEVG bit generates an update event UEV, but the UEVIF flag is not set by hardware (that is, no interrupt or DMA request is sent). This can avoid update and capture interrupt generation when the counter is cleared in capture mode.

When an update event occurs, all the registers are updated, and the update flag (the UEVIF bit in the TMRx\_STS register) is set by hardware (according to the UEVRS bit).

- The repetition counter is reloaded with the content of TMRx\_RC register.
- The auto-reload shadow register is updated with the preload value (TMRx\_AR).
- The buffer of the prescaler is reloaded with the preload value (content of the TMRx\_DIV register).

Figure 10-83 ~ Figure 10-88 show the examples of the counter behaviors for different clock frequencies when  $TMRx\_AR = 0x36$ :









| CK_DIV                                |                                                  |
|---------------------------------------|--------------------------------------------------|
| CNT_EN                                |                                                  |
| Timer clock = CK_CNT                  |                                                  |
| Counter register                      | 0034 X 0035 X 0036 X 0001 X 0002 X 0003 X 0004 X |
| Counter overflow                      |                                                  |
| Update event<br>Update interrupt flag |                                                  |
| (UEVIF)                               |                                                  |

Figure 10-85 Counter Timing Diagram with Internal Clock Divided by 4



Figure 10-86 Counter Timing Diagram with Internal Clock Divided by N



Figure 10-87 Counter Timing Diagram with Update Event When ARPEN = 0 (TMRx\_AR Not Preloaded)



| CK_DIV                           |                                                   |
|----------------------------------|---------------------------------------------------|
| CNTEN                            |                                                   |
| Timer clock = CK_CNT             |                                                   |
| Counter register                 | <u>31 32 33 34 35 36 00 01 02 03 04 05 06 07 </u> |
| Counter overflow                 | Π                                                 |
| Update event                     | 7                                                 |
| Update interrupt flag<br>(UEVIF) |                                                   |
| Auto-reload register             | FF 36                                             |

Figure 10-88 Counter Timing Diagram with Update Event When ARPEN = 1 (TMRx\_AR is Preloaded)



#### Write new values to the TMRx\_AR register

#### **Downcounting mode**

In downcounting mode, the counter counts from the auto-reload value (content of the TMRx\_AR counter) down to 0, and restarts from the auto-reload value and generates a counter underflow event.

If the repetition counter is used, an update event (UEV) is generated after downcounting reaches the programmed count in the repetition counter register (TMRx\_RC). Else, the update event is generated at each counter underflow.



Write new values to the TMRx\_AR register

An update event can also be generated by setting the UEVG bit in the TMRx\_EVEG register (by software or by using the slave mode controller).

Update events can be disabled by setting the UEVDIS bit in the TMRx\_CTRL1 register. This avoids changing the shadow registers while writing new values to the preload registers. Thus, no update event occurs until the UEVDIS bit is cleared. However, the counter still counts from the current auto-reload value, and the prescaler counter restarts from 0 (but the prescaler ratio does not change). In addition, if the UEVRS (update request selection) bit in the TMRx\_CTRL1 register is set, setting the UEVG bit generates an update event UEV, but the UEVIF flag is not set (so no interrupt or DMA request is generated). This can avoid update and capture interrupt generation when a capture event occurs and the counter is cleared.

When an update event occurs, all the registers are updated, and the update flag bit (the UEVIF bit in the TMRx\_STS register) is set (according to the UEVRS bit).

• The repetition counter is reloaded with the content of TMRx\_RC register.

• The current auto-reload register is updated with the preload value (content of the TMRx\_AR register).

• The buffer of the prescaler is reloaded with the preload value (content of the TMRx\_DIV register). Note: Auto-reload is updated before the counter is reloaded, so the next cycle will be the expected value.

Figure 10-89 ~ Figure 10-93 show the examples of the counter behavior for different clock frequencies when TMRx\_AR = 0x36:

Figure 10-89 Counter Timing Diagram with Internal Clock Divided by 1



Figure 10-90 Counter Timing Diagram with Internal Clock Divided by 2



| CK_DIV _                      | תתת  | ЛЛ     |        | ЛЛ   |      |      |        | $\Box$    |
|-------------------------------|------|--------|--------|------|------|------|--------|-----------|
| CNT_EN _                      |      |        |        |      |      |      |        |           |
| Timer clock = CK_CNT          |      | Γ      |        |      |      |      |        |           |
| Counter register              | 0002 | X 0001 | X 0000 | 0036 | 0035 | 0034 | X 0033 | $\subset$ |
| Counter overflow              |      |        |        |      |      |      |        |           |
| Update event                  |      |        |        |      |      |      |        |           |
| Update interrupt flag (UEVIF) |      |        |        |      |      |      |        |           |

Figure 10-91 Counter Timing Diagram with Internal Clock Divided by 4



Figure 10-92 Counter Timing Diagram with Internal Clock Divided by N



Figure 10-93 Counter Timing Diagram of Update Event without Auto-reload





#### Center-aligned mode (Up/Down counting)

In center-aligned mode, the counter counts from 0 to the auto-reload value (content of the TMRx\_AR register) – 1, generates a counter overflow event, and counts from the auto-reload value down to 1 and generates a counter underflow event. Then, it restarts counting from 0.

In this mode, the DIR direction bit in the TMRx\_CTRL1 register cannot be written. It is updated by hardware and indicates the current counting direction.

The update event can be generated at each counter overflow and at each counter underflow, or by setting the UEVG bit in the TMRx\_EVEG register (by software or by using the slave mode controller). Afterwards, the counter as well as the prescaler restarts counting from 0.

The UEV update event can be disabled by setting the UEVDIS bit in the TMRx\_CTRL1 register. This can avoid updating the shadow registers while writing new values to the preload registers. Therefore, no update event occurs until the UEVDIS bit is cleared. However, the counter continues counting up or down based on the current auto-reload value. In addition, if the UEVRS bit (update request selection) in the TMRx\_CTRL1 register is set, setting the UEVG bit generates an update event UEV without setting the UEVIF flag (so no interrupt or DMA request is generated). This can avoid generating both update and capture interrupts when the capture event occurs and the counter is cleared.

When an update event occurs, all the registers are updated, and the update flag bit (the UEVIF bit in the TMRx\_STS register) is set (according to the UEVRS bit).

- The repetition counter is reloaded with the content of TMRx\_RC register.
- The buffer of the prescaler is reloaded with the preload value (content of the TMRx\_DIV register).

## • The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload register is updated with the preload value (content of the TMRx\_AR• The current auto-reload value (content of the TMRx\_AR• The current auto-reload value (content of the TMRx\_AR• The current

register).

Note: If an update is generated because of counter overflow, auto-reload is updated before the counter is reloaded, so the next cycle will be the expected value (the counter is reloaded with the new value).

Figure 10-94 ~ Figure 10-99 show the examples of the counter behavior for different clock frequencies:

Figure 10-94 Counter Timing Diagram with Internal Clock Divided by 1,  $TMRx_AR = 0x6$ 



*Note: Center-aligned mode 1 is used here (Please refer to <u>Section 10.4.4.1</u> for the register description).* 

Figure 10-95 Counter Timing Diagram with Internal Clock Divided by 2



Figure 10-96 Counter Timing Diagram with Internal Clock Divided by 4, TMRx\_AR = 0x36



| CK_INT                        |          |   |      |        |    |      |
|-------------------------------|----------|---|------|--------|----|------|
| CNT_EN                        |          |   |      |        |    |      |
| Timer clock = CK_CNT          | <br>     |   |      |        |    |      |
| Counter register              | <br>0034 | Х | 0035 | V 0036 | _X | 0035 |
| Counter overflow (cnt_ovf) -  |          |   |      |        |    |      |
| Update event (UEV) -          | <br>     |   |      |        |    |      |
| Update interrupt flag (UEVIF) |          |   |      |        |    |      |

Note: Center-aligned mode 2 or 3 is used here, set UEVIF at counter overflow.

### Figure 10-97 Counter Timing Diagram with Internal Clock Divided by N



Figure 10-98 Counter Timing Diagram with Update Event When ARPEN = 1 (Counter underflow)



| CNT_EN                                                       |
|--------------------------------------------------------------|
|                                                              |
| Counter register 06 05 04 03 02 01 00 01 02 03 04 05 06 07 X |
| Counter underflow                                            |
| Update event                                                 |
| Update interrupt flag (UEVIF)                                |
| Auto-reload register FD 36                                   |
| Write new values to the TMRx_AR register                     |
| Active auto-reload register value FD 36                      |

Figure 10-99 Counter Timing Diagram with Update Event When ARPEN = 1 (Counter overflow)



# **10.4.3.3** Repetition Counter

<u>Section 10.4.3.1</u> describes how an update event (UEV) is generated on counter overflows/underflows. It is actually generated only when the repetition counter reaches '0'. This feature can be very useful when generating PWM signals.

This means that when every N times the counter overflows or underflows, data is transferred from the preload registers to the shadow registers (TMRx\_AR auto-reload register, TMRx\_DIV preload register,



also capture/compare registers (TMRx\_CCx in compare mode), where N is the value in the TMRx\_RC repetition counter register.

The repetition counter is decremented under any of the following conditions:

- At each counter overflow in upcounting mode
- At each counter underflow in downcounting mode
- At each counter overflow and at each counter underflow in center -aligned mode

Although this limits the maximum number of repetition to 128 PWM cycles, it makes updating the duty cycle twice per PWM period possible. Because of the symmetry of waveforms, if the compare registers are refreshed only once per PWM period in center-aligned mode, the maximum resolution is 2xT<sub>ck</sub>.

The repetition counter is auto-reloaded, and the repetition rate is defined by the TMRx\_RC register value (Please refer to Figure 10-100). When an update event is generated by software (by setting the UEVG bit in the TMRx\_EVEG register) or by hardware through the slave mode controller, it occurs immediately whatever the value of the repetition counter is, and the repetition counter is reloaded with the content of the TMRx\_RC register.

Figure 10-100 Examples of Updating Rates in Different Modes and the TMRx\_RC Register Configuration





# 10.4.3.4 Clock Selection

The counter clock can be provided by the following clock sources:

- Internal clock (CK\_INT)
- External clock mode 1: External input pin
- External clock mode 2: External trigger input ETR

• Internal trigger inputs (ITRx): Using one timer as the prescaler for another timer. For example, users can configure Timer 1 to act as the prescaler for Timer 2. Please refer to <u>Section 10.4.3.20</u> for more details.

### Internal clock source (CK\_INT)

If the slave mode controller is disabled (SMSEL = 000), the CNTEN, DIR (in the TMRx\_CTRL1 register), and UEVG bits (in the TMRx\_EVEG register) are the actual control bits, and they can be changed only by software (except for the UEVG bit, which will be cleared automatically). As soon as the CNTEN bit is written '1', the prescaler is clocked by the internal clock CK\_INT.

Figure 10-101 shows the behavior of the control circuit and the up counter in normal mode, without



#### prescaler.



#### Figure 10-101 Control Circuit in Normal Mode with Internal Clock Divided by 1

### External clock mode 1

This mode is selected when SMSEL = 111 in the TMRx\_SMC register. The counter can count at each rising or falling edge on a selected input.

Figure 10-102 TI2 External Clock Connection Example



For example, to configure the up counter to count in response to a rising edge on the TI2 input, use the following procedure:

1. Configure channel 2 to detect the rising edges on the TI2 input by writing C2SEL = 01' in the TMRx\_CCM1 register.

2. Configure the input filter duration by writing the IC2DF[3:0] bits in the TMRx\_CCM1 register (if no filter is needed, keep IC2DF = 0000).



- 3. Select the rising edge polarity by writing C2P = 0' in the TMRx\_CCE register.
- 4. Select the timer external clock mode 1 by writing SMSEL = `111' in the TMRx\_SMC register.
- 5. Select TI2 as the trigger input source by writing TRGSEL = 110' in the TMRx\_SMC register.
- 6. Enable the counter by writing CNTEN = 1' in the TMRx\_CTRL1 register.

Note: The capture prescaler is not used as trigger, so it does not need to be configured.

When a rising edge occurs on TI2, the counter counts once, and the TRGIF flag is set.

The delay between the rising edge on TI2 and the actual clock of the counter depends on the resynchronization circuit on TI2 input.

Figure 10-103 Control Circuit in External Clock Mode 1



#### **External clock mode 2**

This mode is selected by writing ECLKEN = 1 in the TMRx\_SMC register.

The counter can count at each rising or falling edge on the external trigger ETR. Figure 10-104 shows the block diagram of the external trigger input.

Figure 10-104 Block Diagram of External Trigger Input





For example, to configure the up counter to count each 2 rising edges on ETR, use the following procedure:

1. Since no filter is needed in this example, write ETDF[3:0] = 0000 in the TMRx\_SMC register.

2. Set the prescaler by writing ETD[1:0] = 01 in the TMRx\_SMC register.

3. Select the rising edge detection on ETR by writing ETRGP = 0 in the TMRx\_SMC register.

4. Enable the external clock mode 2 by writing ECLKEN = 1 in the TMRx\_SMC register.

5. Enable the counter by writing CNTEN = 1 in the TMRx\_CTRL1 register. The counter counts once each 2 ETR rising edges.

The delay between the rising edge on ETR and the actual clock of the counter depends on the resynchronization circuit on the ETRP signal.

Figure 10-105 Control Circuit in External Clock Mode 2



# 10.4.3.5 Capture/Compare Channel

Each capture/compare channel is built around a capture/compare register (including a shadow register),

also an input stage for capture (digital filter, multiplexing, and prescaler) and an output stage (comparator



and output control). Figure 10-106 ~ Figure 10-109 provide an overview of one capture/compare channel.

The input stage samples the corresponding TIx input signal to generate a filtered signal TIxF. Then, an edge detector with polarity selection generates a signal (TIxFPx) which can be the trigger input for the slave mode controller, or be the capture command. This signal enters the capture register (ICxPS) through the prescaler.

Figure 10-106 Capture/Compare Channel (e.g. Channel 1 Input Stage)



The output stage generates an intermediate waveform OCxRef (active high) which serves as reference. The polarity of final output signal is determined by the end of the chain.

Figure 10-107 Capture/Compare Channel 1 Main Circuit





Figure 10-108 Capture/Compare Channel Output Stage (Channel 1 to 3)



Figure 10-109 Capture/Compare Channel Output Stage (Channel 4)





The capture/compare block is made of one preload register and one shadow register . Write and read only access the preload register.

In capture mode, captures are actually done in the shadow register, and then copied into the preload register.

In compare mode, the content of the preload register is copied into the shadow register, and then the content of the shadow register is compared with the counter.

### 10.4.3.6 Input Capture Mode

In input capture mode, the capture/compare registers (TMRx\_CCx) latch the current counter value after a corresponding edge when the ICx signal is detected. When a capture occurs, the corresponding CxIF flag (TMRx\_STS register) is set. An interrupt or a DMA request can be sent if enabled. If a capture occurs when the CxIF flag is already high, the over-capture flag CxOF (TMRx\_STS register) is set. CxIF can be cleared by writing CxIF = 0 or by reading the captured data stored in the TMRx\_CCx register. CxOF = 0 is cleared when writing CxOF = 0.

The following example shows how to capture the counter value to the TMRx\_CC1 register during TI1 input rising edge:

• Select the active input: Write C1SEL = 01 in the TMRx\_CC1 register since the TMRx\_CC1 register must be linked to the TI1 input. The channel is configured as input as long as the C1SEL is not '00'. TMRx\_CC1 register becomes read-only.

• Program the desired input filter duration according to the input signal (if the input is TIx, the



control bit of the input filter is the ICxDF bit in the TMRx\_CCMx register). If the input signal is not stable during five internal clock cycles at most, the filter duration should be configured longer than five clock cycles. Therefore, an actual edged transition on TI1 can be validated by 8 consecutive samples (at fCK\_INT frequency). That is, write IC1DF = 0011 in the TMRx\_CCM1 register.

• Select the active transition edge on the TI1 channel by writing C1P = 0 (rising edge) in the TMRx\_CCE register).

• Program the input prescaler. In this example, each valid transition is expected to be captured, so the prescaler is disabled (write IC1 DIV = 00 in the TMRx\_CCM1 register).

• Set C1EN = 1 in the TMRx\_CCE register to allow the counter value to be captured into the capture register.

• If needed, enable the relevant interrupt request by setting the C1IE bit in the TMRx\_DIE register, and the DMA request by setting the C1DE bit in the TMRx\_DIE register.

When an input capture occurs:

• The counter value is sent to the TMRx\_CC1 register on active transition.

• C1IF flag is set (interrupt flag). When at least two consecutive captures occur and the C1IF flag is not cleared, C1OF is also set.

• An interrupt is generated if the C1IE bit is set.

• A DMA request is generated if the C1DE bit is set.

In case of overcapture, it is recommended that the data is read before the overcapture flag. This is to avoid missing an overcapture information that is generated after reading the overcapture flag and before reading the data.

*Note: Input capture interrupt and/or DMA requests can be generated by setting the corresponding CxG bit in the TMRx\_EVEG register with software.* 

### 10.4.3.7 PWM Input Mode

This mode is a special case of input capture mode. The procedure is the same as input capture mode except for the following conditions:

• Two ICx signals are mapped on the same TIx input.

• The two ICx signals are active on edges but with opposite polarities.



• One of the two TIxFP signals is used as trigger input signal and the slave mode controller is configured as reset mode.

For example, if users need to measure the period (TMRx\_CC1 register) and the duty cycle (TMRx\_CC2 register) of the PWM signal input on TI1, the procedure is as follows (depending on CK\_INT frequency and prescaler value):

• Select the active input for TMRx\_CC1: Write C1SEL = 01 in the TMRx\_CCM1 register (TI1 selected).

• Select the active polarity for TI1FP1 (used to capture data into TMRx\_CC1 and clear the counter): Write C1P = 0 (active on rising edge).

• Select the active input for TMRx\_CC2: Write C2SEL = 10 in the TMRx\_CCM1 register (TI1 selected).

• Select the active polarity for TI1FP2 (capture data to TMRx\_CC2): Write C2P = 1 (active on falling edge).

• Select the valid trigger input signal: Write TRGSEL = 101 in the TMRx\_SMC register (TI1FP1 selected).

• Configure the slave mode controller as reset mode: Write SMSEL = 100 in the TMRx\_SMC register.

• Enable the captures: Write C1EN = 1 and C2EN = 1 in the TMRx\_CCE register.

Figure 10-110 PWM Input Mode Timing



Note: Since only TI1FP1 and TI2FP2 are connected to the slave mode controller, the PWM input mode can be used only with the TMRx\_CH1/TMRx\_CH2 signals.



## 10.4.3.8 Forced Output Mode

In output mode (CxSEL = 00 in the TMRx\_CCMx register), output compare signal (OCxREF and the corresponding OCx/OCxN) can be forced to be active or inactive level directly by software, independent of any comparison between the output compare register and the counter.

To force an output compare signal (OCxREF/OCx) to its active level, users can write the corresponding OCxMODE = 101 in the TMRx\_CCMx register. In this way, OCxREF is forced high (OCxREF is always active high), and at the same time OCx gets the opposite value of the CxP polarity bit.

For example: CxP = 0 (OCx active high), then OCx is forced to be high level.

The OCxREF signal can be forced low by writing OCxMODE = 100 in the TMRx\_CCx register.

In this mode, the comparison between the TMRx\_CCx shadow register and the counter is still ongoing, and the corresponding flag is also modified. Accordingly, the corresponding interrupt and DMA requests are still generated. This will be described in <u>Section 10.4.3.9</u>.

## 10.4.3.9 Output Compare Mode

This function is used to control an output waveform or to indicate that a period of time has elapsed.

When a match is found between the capture/compare register and the counter, the output compare function proceeds as follows:

• Output the value defined by the output compare mode (the OCxMODE bit in the TMRx\_CCMx register) and the output polarity (the CxP bit in the TMRx\_CCE register) to the corresponding pin. When being compared and matched, the output pin can keep its level (OCxMODE = 000), be set active (OCxMODE = 001), be set inactive (OCxMODE = 010), or toggle (OCxMODE = 011).

• Set the flag bit in the interrupt status register ( the CxIF bit in the TMRx\_STS register).

• An interrupt will be generated if the corresponding interrupt mask is set (the CxIE bit in the TMRx\_DIE register).

• A DMA request will be generated if the corresponding enable bit is set (the CxDE bit in the TMRx\_DIE register, the CDSEL bit in the TMRx\_CTRL2 register for the DMA request selection).

The OCxPEN bit in the TMRx\_CCMx register can be configured to choose whether the TMRx\_CCx register uses the preload register.

In output compare mode, the update event UEV has no effect on OCxREF and OCx output.



Hangzhou Vango Technologies, Inc.

The timing resolution can reach one count of the counter. Output compare mode can also be used to output a single pulse (in one-pulse mode).

Output compare mode configuration procedure is as follows:

- 1. Select the counter clock (internal, external, and prescaler).
- 2. Write the corresponding data to the TMRx\_AR and the TMRx\_CCx registers.
- 3. Set the CCxIE bit if an interrupt request is to be generated.
- 4. Select the output mode. For example:

– When the counter and the CCx bit is matched, toggle the output pin of OCx, configure OCxMODE = '011'

- Set OCxPEN = 0, disable the preload register
- Set CxP = 0, select polarity as active high
- Set CxEN = 1, enable output
- 5. Enable the counter by setting the CNTEN bit in the TMRx\_CTRL1 register.

The TMRx\_CCx register can be updated at any time by software to control the output waveform, under the condition that the preload register is not enabled (OCxPEN = '0'; else, the TMRx\_CCx shadow register can only be updated at the next update event). An example is shown in Figure 10-111.

Figure 10-111 Output Compare Mode, Toggle on OC1



### 10.4.3.10 PWM Mode

Pulse width modulation mode can generate a signal with its frequency determined by the TMRx\_AR register and its duty cycle determined by TMRx\_CCx register.

Writing '110' (PWM mode 1) or '111' (PWM mode 2) in the OCxMODE bit in the TMRx\_CCMx register can independently configure each OCx output channel and generate single-channel PWM. The OCxPEN bit in the TMRx\_CCMx register must be configured to enable the corresponding preload register. Finally, the ARPEN bit in the TMRx\_CTRL1 register (in upcounting or center-aligned modes) must be set to enable the auto-reload preload register.

Since the preload registers are transferred to the shadow registers only when an update event occurs, before starting the counter, users must initialize all the registers by setting the UEVG bit in the TMRx\_EVEG register. OCx polarity is software programmable by setting the CxP bit in the TMRx\_CCE register. It can be programmed as active high or active low. OCx output enable is controlled by the combination of the CxEN, CxNEN, MOEN, OSIMI, and OSIMR bits (in the TMRx\_CCE and TMRx\_BRKDT registers). Please refer to the description of TMRx\_CCE register for more details.

In PWM mode (1 or 2), TMRx\_CNT and TMRx\_CCx are always compared (according to the direction of the counter) to confirm that TMRx\_CCx  $\leq$  TMRx\_CNT or TMRx\_CNT  $\leq$  TMRx\_CCx.

The timer can generate the edge-aligned or center-aligned PWM signal according to the status of the CMSEL bit in the TMRx\_CTRL1 register.

#### PWM edge-aligned mode

### • Upcounting configuration

Upcounting is active when the DIR bit in the TMRx\_CTRL1 register is low. Please refer to Section 10.4.3.2.

The following is an example of PWM mode 1. The reference PWM signal, OCxREF, is high once TMRx\_CNT < TMRx\_CCx; else, it becomes low. If the compare value in TMRx\_CCx is greater than the auto-reload value (in TMRx\_AR), OCxREF is held at '1'.

If the compare value is 0, then OCxREF is held at '0'. Figure 10-112 shows an example of edge-aligned PWM waveforms with TMRx\_AR = 8.

Figure 10-112 Edge-aligned PWM Waveforms (AR = 8)





#### • Downcounting configuration

Downcounting is active when the DIR bit in the TMRx\_CTRL1 register is high. Please refer to <u>Section</u> <u>10.4.3.2</u>. In PWM mode 1, the reference signal, OCxREF, is low once MRx\_CNT > TMRx\_CCx; else, it becomes high. If the compare value in TMRx\_CCx is greater than the auto-reload value in TMRx\_AR, then OCxREF is held at `1'. 0% PWM is not possible in this mode.

#### **PWM center-aligned mode**

Center-aligned mode is active when the CMSEL bit in the TMRx\_CTRL1 register is not '00' (all the other configurations have the same effect on the OCxREF/OCx signals). According to different CMSEL bit configurations, the compare flag is set when the counter counts up, counts down, or counts both up and down. The direction bit (DIR) in the TMRx\_CTRL1 register is updated by hardware and must not be changed by software. Please refer to the center-aligned mode in Section 10.4.3.2. Figure 10-113 shows several center-aligned PWM waveforms in an example where:

- TMRx\_AR = 8
- PWM mode 1

• The compare flag is set when the counter counts down, center -aligned mode 1 is selected, and CMSEL = 01 in the TMRx\_CTRL1 register.

Figure 10-113 Center-aligned PWM Waveforms (AR = 8)





#### Hints on using center-aligned mode:

• When entering the center-aligned mode, the current up/down configuration is used. This means whether the counter counts up or down depends on the current value of the DIR bit in the TMRx\_CTRL1 register. In addition, the DIR and CMSEL bits cannot be changed by software at the same time.

• In center-aligned mode, writing to the counter while running is not recommended as it may lead to unexpected results. In particular:

If the value written to the counter is greater than the auto-reload value (TMRx\_CNT > TMRx\_AR),
 the direction will not be updated. For example, if the counter is counting up, it will keep counting up.

The direction is updated if 0 or the TMRx\_AR value is written to the counter, but no update event
 UEV will be generated.

The safest way to use the center-aligned mode is to generate an update by software (setting the UEVG bit in the TMRx\_EVEG register) before enabling the counter, and do not write the counter while it is running.



### 10.4.3.11 Complementary Output and Dead-time Insertion

The advanced-control timers (TMR1 and TMR8) can output two complementary signals and manage the switching-off and the switching-on instants of the outputs. This time is generally known as dead-time. Users can adjust dead-time according to the devices connected to the outputs and their characteristics (intrinsic delays of level-shifters, delays resulted from power switches, etc.)

Setting the CxP and CxNP bits in the TMRx\_CCE register can select the polarity (main output OCx or complementary OCxN) for each output independently.

The complementary signals, OCx and OCxN, are activated by the combination of the following control bits: CxEN and CxNEN bits in the TMRx\_CCE register, the MOEN, OCxIS, OCxNIS, OSIMI, and OSIMR bits in the TMRx\_BRKDT and TMRx\_CTRL 2 register. Please refer to Table 10-9 for more details on output control bits for complementary OCx and OCxN channels with break feature. In particular, the dead-time is activated when switching to the IDLE state (MOEN falling down to 0).

Setting CxEN and CxNEN bits at the same time will insert dead-time. The MOEN bit should also be set if there is break circuit. Every channel has a10-bit dead-time generator. Reference signal, OCxREF, can generate two outputs, OCx and OCxN. If OCx and OCxN are active high:

• The OCx output signal is the same as the reference signal , but its rising edge is delayed compared to the reference signal rising edge.

• The OCxN output signal is the opposite of the reference signal, but its rising edge is delayed compared to the reference signal falling edge.

If the delay is greater than the width of the active output (OCx or OCxN), the corresponding pulse is not generated.

Figure 10-114 ~ Figure 10-116 show the relationship between the output signals of the dead-time generator and the reference signal, OCxREF. (Assuming that CxP = 0, CxNP = 0, MOEN = 1, CxEN = 1, and CxNEN = 1)

Figure 10-114 Complementary Output with Dead-time Insertion









Figure 10-116 Dead-time Waveform Delay Which is Greater than Positive Pulse



The dead-time delay is the same for each channel, and is programmable with the DTGS bits in the TMRx\_BRKDT register. Please refer to <u>Section 10.4.4.18</u> for delay calculation.

### **Re-directing OCxREF to OCx or OCxN**

In output mode (forced, output compare, or PWM), OCxREF can be re-directed to the OCx output or to OCxN output by configuring the CxEN and CxNEN bits in the TMRx\_CCE register.

This function allows the user to send a specific waveform (such as PWM or static active level) on one output while the complementary output remains at its inactive level. Another usage is to put both outputs at inactive level, or at active level to be complementary with dead-time.

Note: When only OCxN is enabled (CxEN = 0, CxNEN = 1), it is not inverted and becomes active as soon as OCxREF is high. For example, if CxNP = 0, then OCxN = OCxRef. On the other hand,



when both OCx and OCxN are enabled (CxEN = CxNEN = 1), OCx becomes active when OCxREF is high, whereas OCxN becomes active when OCxREF is low.

# 10.4.3.12 Using the Break Function

When using the break function, the output enable signals and inactive levels are modified according to the corresponding control bits (the MOEN, OSIMI, and OSIMR bits in the TMRx\_BRKDT register, the OCxIS and OCxNIS bits in the TMRx\_CTRL2 register). In any case, OCx and OCxN outputs cannot both be set to active level at the same time. Please refer to Table 10-9 for more details.

The break source can be the break input pin or a clock failure event. A clock failure event is generated by the clock security system in the reset clock controller. For further information, please refer to <u>Section 3.2.7</u>.

After system reset, the break circuit is disabled, and the MOEN bit is low. Users can enable the break function by setting the BRKEN bit in the TMRx\_BRKDT register. The break input polarity can be selected by configuring the BRKP bit in the same register. BRKEN and BRKP can be modified at the same time. When the BRKEN and BRKP bits are written, a delay of 1 APB clock cycle is applied before the writing is effective. Consequently, it is necessary to wait for 1 APB clock period to correctly read the written bit.

Because MOEN falling edge can be asynchronous, a resynchronization circuit is inserted between the actual signal (acting on the outputs) and the synchronous control bit (in the TMRx\_BRKDT register). The resynchronization circuit generates delays between the asynchronous and the synchronous signals. In particular, if MOEN = 1 when it is low, a delay (dummy instruction) must be inserted before reading it. This is because an asynchronous signal is written, but a synchronous signal is read.

When a break occurs (selected level occurs on the break input), there will be the following actions:

• The MOEN bit is cleared asynchronously, putting the outputs at inactive state, idle state, or at reset state (selected by the OSIMI bit). This feature func tions even if the MCU oscillator is off.

• Once MOEN = 0, each output channel is driven with the level programmed in the OCxIS bit in the TMRx\_CTRL2 register. If OSIMI = 0, the timer releases the enable output; else, the enable output remains high.

• When complementary outputs are used:

- The outputs are first put at reset state, namely, 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 present, then the dead-time generator is reactivated in order to drive theHangzhou Vango Technologies, Inc.381 / 782

outputs with the level programmed in the OCxIS and OCxNIS bits after a dead-time. Even in this case, OCx and OCxN cannot be driven to their active levels at the same time.

Please note that because of the resynchronization on MOEN, the dead-time duration is a bit longer than usual (around 2 ck\_tim clock cycles).

- If OSIMI = 0, the timer releases the enable output; else, keeps the enable output. Or the enable output becomes high as soon as one of the CxEN and CxNEN bits becomeshigh.

• If the BRKIE bit in the TMRx\_DIE register is set, an interrupt can be generated when the break status flag (the BRKIF bit in the TMRx\_STS register) is set. A DMA request can be sent if the BDE bit in the TMRx\_DIE register is set.

• If the AOEN bit in the TMRx\_BRKDT register is set, the MOEN bit is automatically set again at the next update event UEV. This can be used to perform a regulation, for instance. Otherwise, MOEN remains low until it is set again. This feature can be used for security purposes. The break input can be connected to an alarm from power drivers, thermal sensors, or any security components. *Note: The break inputs are acting on level. Thus, MOEN cannot be set while the break input is active (neither automatically nor by software). In the meantime, the status flag, BIF, cannot be cleared.* 

The break is generated by the BRK input which has a programmable polarity, and is enabled by the BRKEN bit in the TMRx\_BRKDT register.

In addition to break input and output management, a write protection is implemented inside the break circuit to safeguard the application. It allows freezing the configuration of several parameters (dead-time duration, OCx/OCxN polarities and state when disabled, OCxMODE configurations, break enable and polarity).

Users can choose from three levels of protection through the LOCKC bits in the TMRx\_BRKDT register. Please refer to <u>Section 10.4.4.18</u>. The LOCKC bits can be written only once after an MCU reset.

Figure 10-117 shows an example of the output behavior in response to a break.

Figure 10-117 Outputs in Response to a Break





# 10.4.3.13 Clearing OCxREF Signal on an External Event

For a given channel, a high level of the ETRF input can lower the OCxREF signal if the corresponding OCxDIS bit in the TMRx\_CCMx register is set. The OCxREF signal remains low until the next update event, UEV, occurs.

This function can only be used in output compare and PWM modes, and does not work in the forced output mode.

For example, the OCxREF signal can be connected to a comparator output for current control. In this



case, ETR must be configured as follows:

1. The external trigger prescaler should be kept OFF: ETD[1:0] = '00' in the TMRx\_SMC register.

2. The external clock mode 2 must be disabled: ECLKEN = '0' in the TMRx\_SMC register.

3. The external trigger polarity (ETRGP) and the external trigger filter (ETDF) can be configured according to users' needs.

Figure 10-118 shows how OCxREF signal behaves to respond to different OCxDIS values when the ETRF input becomes high. In this example, the timer TMRx is programmed in PWM mode.

Figure 10-118 Clearing OCxREF in TMRx



### 10.4.3.14 6-step PWM Output Generation

When complementary outputs are used on a channel, preload bits are the OCxMODE, CxEN, and CxNEN bits. The preload bits are transferred to the shadow bits at the HALL commutation event. In this way, users can program the configuration for the next step in advance and change the configuration of all the channels at the same time. HALL can be generated by setting the HALL bit in the TMRx\_EVEG register through software or on TRGI rising edge by hardware.

A flag (the HALLIF bit in the TMRx\_STS register) is set when the HALL event occurs. If the HALLIE bit in the TMRx\_DIE register is set at this time, an interrupt will be generated. If the HALLDEB bit is set in the TMRx\_DIE register, a DMA request will be generated.

Figure 10-119 shows the behavior of the OCx and OCxN outputs in 3 different configurations when a HALL event occurs.







# 10.4.3.15 One-pulse Mode

One-pulse mode (OPMODE) is quite different from the above-mentioned modes. It allows the counter to respond to a stimulus and to generate a pulse with a programmable length after a programmable delay.

The counter can be enabled through the slave mode controller, generating waveforms in output compare mode or PWM mode. One-pulse mode is selected by setting the OPMODE bit in the TMRx\_CTRL1 register, and this can stop the counter automatically at the next update event UEV.



A pulse can be generated only if the compare value is different from the initial counter value. Before enabling (when the timer is waiting for the trigger), the following configuration must be done:

- In upcounting:  $CNT < CCx \le AR$  (especially, 0 < CCx)
- In downcounting: CNT > CCx

Figure 10-120 One-pulse Mode Example



For example, if users want to generate a positive pulse with a length of t<sub>PULSE</sub> on OC1 once a rising edge is detected on the TI2 input pin and after a delay tDELAY.

If TI2FP2 is used as trigger 1:

- Map TI2FP2 to TI2 by writing C2SEL = '01' in the TMRx\_CCM1 register.
- Write C2P = '0' in the TMRx\_CCE register to enable TI2FP2 to detect a rising edge.

• Write TRGSEL = '110' in the TMRx\_SMC register to make TI2FP2 the trigger of the slave mode controller (TRGI).

• Write SMSEL = `110' in the TMRx\_SMC register (trigger mode), and TI2FP2 is used to enable the counter.

The OPMODE waveform is defined by the value written to the compare registers (the clock frequency and the counter prescaler should be taken into account).

 $\bullet$   $t_{\text{DELAY}}$  is defined by the value written to the TMRx\_CC1 register.



Hangzhou Vango Technologies, Inc.

• t<sub>PULSE</sub> is defined by the comparison result of auto-reload value and the compare value (TMRx\_AR - TMRx\_CC1).

• Assume that users want to generate a waveform with a transition from '0' to '1' when a compare match occurs, and a transition from '1' to '0' when the counter reaches the preload value. First, set OC1MODE = '111' in the TMRx\_CCM1 register to enter PWM mode 2. Enable the desired preload registers by setting OC1PEN = '1' in the TMRx\_CCM1 register and the ARPEN bit in the TMRx\_CTRL1 register. Afterwards, write compare value in the TMRx\_CC1 register, write auto-reload value in the TMRx\_AR register, modify the UEVG bit to generate an update event, and wait for an external trigger event on TI2. In this example, C1P = '0'.

In this example, the DIR and CMSEL bits in the TMRx\_CTRL1 register should be low. Since only one pulse is needed, '1' must be written to the OPMODE bit in the TMRx\_CTRL1 register to stop the counter at the next update event (when the counter rolls over to 0 from the auto-reload value).

#### Special case: OCx fast enable

In one-pulse mode, the counter is enabled by setting the CNTEN bit on the edge detection logic of TIx input pin. Then, the comparison between the counter and the compare value makes output toggle. However, since several clock cycles are needed for these operations, it limits the minimum delay  $t_{DELAY}$  users can get.

The OCxFEN bit in the TMRx\_CCMx register can be set to output a waveform with the minimum delay. In this case, OCxREF (and OCx) are forced to respond to the stimulus, instead of relying on the comparison result. The waveform outputted is the same as the one being compared and matched. OCxFEN acts only if the channel is configured as PWM1 or PWM2 mode.

### 10.4.3.16 Encoder Interface Mode

To select the encoder interface mode, write SMSEL = 001 in the TMRx\_SMC register if the counter is counting on TI2 edges only; write SMSEL = 010 if it is counting on TI1 edges only; write SMSEL = 011 if it is counting on both TI1 and TI2 edges.

Select the TI1 and TI2 polarity by programming the C1P and C2P bits in the TMRx\_CCE register. Users can program the input filter as well when it is needed.

The two inputs, TI1 and TI2, are used as the interface of incremental encoder. Please refer to Table 10-7. If the counter is enabled (CNTEN = 1' in the TMRx\_CTRL1 register), it is clocked by each valid transition



on TI1FP1 or TI2FP2. TI1FP1 and TI2FP2 are the signals of TI1 and TI2 after input filter and polarity selection. If not filtered and not inverted, TI1FP1 = TI1 and TI2FP2 = TI2. Count pulses and direction signal are generated according to the transition sequence of the two inputs. The counter counts up or down according to the transition sequence of the two inputs, and at the same time the DIR bit in the TMRx\_CTRL1 register is set accordingly by hardware.

The DIR bit is re-calculated at each transition on any input (TI1 or TI2), no matter the counter is counting on TI1 only, TI2 only, or both TI1 and TI2.

Encoder interface mode basically acts like an external clock with direction selection. This means that the counter just counts continuously between 0 and the auto-reload value in the TMRx\_AR register (0 to AR or ARR down to 0, depending on the direction). Hence, the TMRx\_AR register must be configured before the counting starts. Likewise, features of the capture, comparator, prescaler, repetition counter, and trigger output work as usual. Encoder mode and external clock mode 2 are not compatible, so they cannot be used at the same time.

In this mode, the counter is modified automatically according to the speed and the direction of the incremental encoder. Therefore, its content always indicates the position of the encoder. The counting direction corresponds to the rotation direction of the connected sensor. Table 10-7 lists all the possible combinations, assuming that TI1 and TI2 do not switch at the same time.

| Active Edge     | Level on Opposite Signal       | TI1FP1 Sign | ial      | TI2FP2 Signal |          |
|-----------------|--------------------------------|-------------|----------|---------------|----------|
| Active Luge     | (TI1FP1 to TI2, TI2FP2 to TI1) | Rising      | Falling  | Rising        | Falling  |
| Counting on TI1 | High                           | Down        | Up       | No count      | No count |
| only            | Low                            | Up          | Down     | No count      | No count |
| Counting on TI2 | High                           | No count    | No count | Up            | Down     |
| only            | Low                            | No count    | No count | Down          | Up       |
| Counting on TI1 | High                           | Down        | Up       | Up            | Down     |
| and TI2         | Low                            | Up          | Down     | Down          | Up       |

Table 10-7 Counting Direction and Encoder Signals

An external incremental encoder can be connected directly to MCU without external interface logic. However, comparators are normally used to convert the encoder's differential outputs to digital signals. This greatly increases noise immunity. The third encoder output signal, which indicates the mechanical



zero position, can be connected to an external interrupt input to trigger a counter reset.

Figure 10-121 provides an example of counter operation, showing counting signal generation and direction control. It also shows how input jitter is compensated when both edges are selected. Jitters might occur if the sensor is positioned near to one of the switching points. For example, assume that the configuration is the following:

- •C1SEL = '01' (TMRx\_CCM1 register, IC1FP1 is mapped on TI1.)
- •C2SEL = '01' (TMRx\_CCM1 register, IC2FP2 is mapped on TI2.)
- •C1P = '0' (TMRx\_CCE register, IC1FP1 not inverted, IC1FP1 = TI1)
- •C2P = '0' (TMRx\_CCE register, IC2FP2 not inverted, IC2FP2 = TI2)
- •SMSEL = '011' (TMRx\_SMC register, all inputs are active on both rising and falling edges.)
- ●CNTEN = `1' (TMRx\_CTRL1 register, counter enabled)

Figure 10-121 Example of Counter Operation in Encoder Interface Mode



Figure 10-122 is an example of counter behavior when IC1FP1 polarity is inverted (the same configuration as the above example, except for C1P = 1').

Figure 10-122 Example of Encoder Interface Mode with IC1FP1 Polarity Inverted





The timer, when configured as encoder interface mode, provides information on the sensor's current position. Using the second timer configured in capture mode can measure the interval period between two encoder events to obtain the dynamic information (speed, acceleration, and deceleration). The encoder output which indicates the mechanical zero can be used for this purpose. Based on the interval between two events, the counter can also be read regularly. If possible, users can latch the counter value into the third input capture register (the capture signal must be periodic and can be generated by another timer). It is also possible to read its value through a DMA request generated by a real-time clock.

### **10.4.3.17 Timer Input XOR Function**

The TI1SEL bit in the TMRx\_CTRL2 register allows the input filter of channel 1 to be connected to the output of an XOR gate, which includes three input pins, TMRx\_CH1, TMRx\_CH2, and TMRx\_CH3.

The XOR output can be used with all the timer input functions, such as trigger or input capture. An example of this feature used to interface Hall sensors is listed in the next section.

# 10.4.3.18 Interfacing with Hall Sensors

When using the advanced-control timer (TMR1 and TMR8) to generate PWM signal which drives the motor, another general-purpose timer TMRx (TMR2, TMR3, TMR4, or TMR5) can function as "interfacing timer" to connect Hall sensors. Please refer to Figure 10-123. The 3 timer input pins (CC1, CC2, and CC3) are connected to the TI1 input channel (selected by setting the TI1SEL bit in the TMRx\_CTRL2 register) through an XOR gate, and the "interfacing timer" captures this signal.



The slave mode controller is configured in reset mode; the slave input is TI1F\_ED. Each time when one of the 3 inputs toggles, the counter restarts counting from 0. This creates a time base triggered by any change on the Hall inputs.

On the "interfacing timer", capture/compare channel 1 is configured in capture mode, capture signal is TRC (see Figure 10-106). The captured value, which reflects the time delay between the 2 changes on the inputs, provides information about motor speed.

The "interfacing timer" can be used in output mode to generate a pulse which can change the channel configuration of the advanced-control timer TMR1 and TMR8 (by triggering a HALL event). The PWM signal generated by advanced-control timers can drive the motor.

Therefore, the interfacing timer channel must be programmed so that a positive pulse is generated after a programmed delay (in output compare or PWM mode). This pulse is sent to the advanced-control timer (TIM1 and TIM8) through the TRGO output.

For example: To change the PWM configuration of the advanced-control timer TMRx at a given time after any change occurs on the Hall inputs connected to the TMRx timer:

• Configure 3 timer inputs ORed to the TI1 input by writing the TI1SEL bit in the TMRx\_CTRL2 register to `1'.

• Program the time base: Set the TMRx\_AR to the max. value (the counter must be cleared by the TI1 change.) Set the prescaler to get a maximum counter period longer than the time between 2 changes on the sensors.

• Program channel 1 in capture mode (TRC selected): Write C1SEL = 11 in the TMRx\_CCM1 register. The digital filter can also be configured if needed.

• Program channel 2 in PWM 2 mode with the desired delay: Write OC2MODE = 111 and C2SEL = 00 in the TMRx\_CCM1register.

• Select OC2REF as trigger output on TRGO: Write MMSEL = 101 in the TMRx\_CTRL2 register.

In the advanced-control register TMR1, the correct ITR input must be trigger input. The timer is programmed to generate PWM signals, and the capture/compare control signals are preloaded (CPC = 1 in the TMRx\_CTRL2 register), and at the same time the HALL event is controlled by the trigger input (CUSEL = 1 in the TMRx\_CTRL2 register). The PWM control bits (CxEN, OCxMODE) for the next step are written after a HALL event. This can be done in an interrupt subroutine generated by the rising edge of OC2REF).

Figure 10-123 shows the example.

ango





# 10.4.3.19 TMRx Timer and External Trigger Synchronization

The TMRx timer can be synchronized with an external trigger in several modes: reset mode, gated mode, and trigger mode.

### Slave mode: Reset mode

The counter and its prescaler can be reinitialized when a trigger input event occurs. In this case, if the UEVRS bit of the TMRx\_CTRL1 register is low, an update event UEV is generated. Then, all the preloaded registers (TMRx\_AR, TMRx\_CCx) will be updated.

In the following example, the up counter is cleared due to a rising edge on TI1 input:



Hangzhou Vango Technologies, Inc.

• Configure channel 1 to detect the rising edges on TI1. Configure the input filter duration (in this example, no filter is needed, so keep IC1DF = 0000). The capture prescaler is not used for triggering, so it does not need to be configured. The C1SEL bit selects the input capture source only, that is, C1SEL = 01 in the TMRx\_CCM1 register. Write C1P = 0 in the TMRx\_CCE register to confirm the polarity (and detect rising edges only).

• Configure the timer as reset mode by writing SMSEL = 100 in the TMRx\_SMC register. Select TI1 as the input source by writing TRGSEL = 101 in the TMRx\_SMC register.

• Start the counter by writing CNTEN = 1 in the TMRx\_CTRL1 register.

The counter starts counting on the internal clock, and runs normally until TI1 rising edge occurs; at this time, the counter is cleared and restarts from 0. In the meantime, the trigger flag (the TRGIF bit in the TMRx\_STS register) is set, and an interrupt request, or a DMA request can be sent depending on the configuration of the TRGIE bit in the TMRx\_DIE register (interrupt enable) and the TRGDE bits in TMRx\_DIE register (DMA enable). Figure 10-124 shows the behavior when the auto-reload register TMRx\_AR = 0x36. The delay between the rising edge on TI1 and the actual reset of the counter is determined by the resynchronization circuit on TI1 input.

Figure 10-124 Control Circuit in Reset Mode



#### Slave mode: Gated mode

The counter can be enabled according to the selected level of input.

In the following example, the counter counts up only when TI1 input is low:

• Configure channel 1 to detect low levels on TI1. Configure the input filter duration (in this example, no filter is needed, so keep IC1DF = 0000). The capture prescaler is not used for triggering, so it does not need to be configured. The C1SEL bits select the input capture source. Set C1SEL = 01 in the TMRx\_CCM1 register. Write C1P = 1 in the TMRx\_CCE register to confirm Hangzhou Vango Technologies, Inc. 393 / 782 the polarity (and detect low level only).

• Configure the timer as gated mode by writing SMSEL = 101 in the TMRx\_SMC register. Select TI1 as the input source by writing TRGSEL = 101 in the TMRx\_SMC register.

• Enable the counter by writing CNTEN = 1 in the TMRx\_CTRL1 register. In gated mode, the counter cannot be enabled if CNTEN = 0, no matter what the trigger input level is.

The counter starts counting on the internal clock as long as TI1 is low and stops as soon as TI1 becomes high. The TRGIF flag in the TMRx\_STS register is set both when the counter starts and stops.

The delay between the rising edge on TI1 and the actual stop of the counter is determined by the resynchronization circuit on TI1 input.

Figure 10-125 Control Circuit in Gated Mode



#### Slave mode: Trigger mode

The counter can be enabled according to the selected level of input.

In the following example, the counter starts to count up at rising edge on TI2 input:

• Configure channel 2 to detect the rising edge on TI2. Configure the input filter duration (in this example, no filter is needed, so keep IC1DF = 0000). The capture prescaler is not used for triggering, so it does not need to be configured. The C2SEL bits are only used to select the input capture source. Set C2SEL = 01 in the TMRx\_CCM1 register. Write C2P = 0 in the TMRx\_CCE register to confirm the polarity (and detect low level only).

• Configure the timer as trigger mode by writing SMSEL = 110 in the TMRx\_SMC register. Select TI2 as the input source by writing TRGSEL = 110 in the TMRx\_SMC register.



The counter starts counting on the internal clock as long as a rising edge occurs on TI2, and at the same time the TRGIF flag is set.

The delay between the rising edge on TI2 and enabling counting is determined by the resynchronization circuit on TI2 input.

Figure 10-126 Control Circuit in Trigger Mode



### Slave mode: External Clock Mode 2 + Trigger Mode

The external clock mode 2 can be used with another slave mode (except for external clock mode 1 and encoder mode). In this case, the ETR signal is used as external clock input, and another input can be trigger input in reset mode, gated mode, or trigger mode. Selecting ETR as TRGI through the TRGSEL bits in the TMRx\_SMC register is not recommended.

In the following example, as soon as a rising edge of TI1 occurs, the counter counts up once at each rising edge of the ETR signal:

- 1. Configure the external trigger input circuit through the TMRx\_SMC register:
  - ETDF = 0000: No filter
  - ETD = 00: Prescaler is disabled.

- ETRGP = 0: Detect the rising edges on ETR and set ECLKEN = 1 to enable the external clock mode 2.

2. Configure channel 1 as follows to detect the rising edges on TI:

- IC1DF = 0000: No filter
- The capture prescaler is not used for triggering and does not need to be configured.

- Set C1SEL = 01 in the TMRx\_CCM1 register to select the input capture source.

ango

- Set C1P = 0 in the TMRx\_CCE register to confirm polarity (and detect rising edge only).

3. Configure the timer as trigger mode by writing SMSEL = 110 in the TMRx\_SMC register. Select TI1 as the input source by writing TRGSEL = 101 in the TMRx\_SMC register.

A rising edge on TI1 enables the counter and sets the TRGIF flag. The counter then counts on ETR rising edges. The delay between the rising edge of the ETR signal and the actual reset of the counter is determined by the resynchronization circuit on ETRP input.

Figure 10-127 Control Circuit in External Clock Mode 2 + Trigger Mode



# 10.4.3.20 Timer Synchronization

All TMR timers are connected internally for synchronization or chaining. Please refer to Section 10.2.3.5 for more details.

# 10.4.3.21 Debug Mode

When the microcontroller enters debug mode (Cortex<sup>®</sup>-M4F core halted), the TMRx counter either continues to work normally or stops, depending on DBG\_TMRx\_STOP configuration in DBG module. For more details, please refer to Section 22.2.2.

# 10.4.4 TMR1 and TMR8 Registers Description

# 10.4.4.1 TMR1 and TMR8 Control Register 1 (TMRx\_CTRL1)

Address offset: 0x00

Reset value: 0x0000



| Bit       | Name          | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|-----------|---------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit 15:10 | -             | -    | Reserved. Always read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Bit 9:8   | CLKDIV[1:0]   | rw   | Clock division<br>Define the division ratio between the timer clock (CK_INT)<br>frequency, dead-time, and sampling frequency used by the<br>dead-time generator and digital filters (ETR, TIx).<br>00: t <sub>DTS</sub> = t <sub>CK_INT</sub><br>01: t <sub>DTS</sub> = 2 x t <sub>CK_INT</sub><br>10: t <sub>DTS</sub> = 4 x t <sub>CK_INT</sub><br>11: Reserved, do not use this configuration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| Bit 7     | ARPEN         | rw   | <ul><li>Auto-reload preload enable</li><li>0: TMRx_AR register is not buffered.</li><li>1: TMRx_AR register is buffered.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| Bit 6:5   | CMSEL[1:0] rw |      | Center-aligned mode selection<br>00: Edge-aligned mode. The counter counts up or down<br>depending on the direction bit (DIR).<br>01: Center-aligned mode 1. The counter counts up and down<br>alternatively. Output compare interrupt flags of channels<br>configured as output (CxSEL = 00 in the TMRx_CCMx register)<br>are set only when the counter is counting down.<br>10: Center-aligned mode 2. The counter counts up and down<br>alternatively. Output compare interrupt flags of channels<br>configured as output (CxSEL = 00 in the TMRx_CCMx register)<br>are set only when the counter is counting up.<br>11: Center-aligned mode 3. The counter counts up and down<br>alternatively. Output compare interrupt flags of channels<br>configured as output (CxSEL = 00 in the TMRx_CCMx register)<br>are set only when the counter is counting up.<br>11: Center-aligned mode 3. The counter counts up and down<br>alternatively. Output compare interrupt flags of channels<br>configured as output (CxSEL = 00 in the TMRx_CCMx register)<br>are set both when the counter is counting up or down.<br><i>Note: It is not allowed to switch from edge-aligned mode to</i><br><i>center-aligned mode when the counter is enabled (CNTEN =</i><br>1). |  |  |



| Bit 4       DIR       rw       Direction         Bit 4       DIR       rw       1: The counter counts up.         Note: This bit is read-only when the counter is configure         center-aligned mode or encoder mode.         Bit 3       OPMODE         rw       0: The counter does not stop at update event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ed in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0: The counter does not stop at update event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 1: The counter stops at the next update event (The CN         is cleared).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | TEN bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Bit 2UEVRSrwSources.Bit 2UEVRSrw- Counter overflow/underflow<br>- Setting the UEVG bit<br>- An update is generated from the slave mode controlled<br>1: Only counter overflow/underflow generates an update                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <ul> <li>This bit is set and cleared by software to select the UEV event sources.</li> <li>0: Any of the following events generates an update interrupt or DMA request if update interrupt or DMA request is enabled:</li> <li>Counter overflow/underflow</li> <li>Setting the UEVG bit</li> <li>An update is generated from the slave mode controller.</li> <li>1: Only counter overflow/underflow generates an update interrupt or DMA request is update interrupt or DMA request is update interrupt or DMA request is update</li> </ul> |  |  |
| Bit 1       UEVDIS       rw       Update disable         This bit is set and cleared by software to enable/disate event generation.       0: UEV is enabled. An update event (UEV) is generated of the following events:         - Counter overflow/underflow       - Setting the UEVG bit         - An update is generated from the slave mode co         Buffered registers are loaded with their preload values         1: UEV is disabled. Update events are not generated shadow registers (AR, DIV, and CCx) keep their value counter and the prescaler are reinitialized if the UEVG to the prescaler are prescaler are reinitialized if the UEVG to the prescaler are prescaler are prescaler are prescaler are prescaler are pr | l by any<br>ntroller.<br>s.<br>ed, and<br>ies. The                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| Hangzhou Vango Technologies, Inc. 39                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 8 / 782                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |

|       |       |    | or the slave mode controller sends a hardware reset.                                                                   |
|-------|-------|----|------------------------------------------------------------------------------------------------------------------------|
|       |       |    | Counter enable                                                                                                         |
|       |       |    | 0: The counter is disabled.<br>1: The counter is enabled.<br>Note: External clock, gated mode, and encoder mode can wo |
| Bit 0 | CNTEN | rw |                                                                                                                        |
|       |       |    |                                                                                                                        |
|       |       |    | only after the CNTEN bit is previously set by software. Trigger                                                        |
|       |       |    | mode can set the CNTEN bit automatically by hardware.                                                                  |

### 10.4.4.2 TMR1 and TMR8 Control Register 2 (TMRx\_CTRL2)

Address offset: 0x04

| Bit    | Name   | Туре | Description                                                                                                                                                                                                                                |  |
|--------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 15 | -      | -    | Reserved. Always read as 0.                                                                                                                                                                                                                |  |
| Bit 14 | OC4IS  | rw   | Output idle state 4 (OC4 output). Please refer to the OC1IS bit.                                                                                                                                                                           |  |
| Bit 13 | OC3NIS | rw   | Output idle state 3 (OC3N output). Please refer to the OC1NIS bit.                                                                                                                                                                         |  |
| Bit 12 | OC3IS  | rw   | Output idle state 3 (OC3 output). Please refer to the OC1IS bit.                                                                                                                                                                           |  |
| Bit 11 | OC2NIS | rw   | Output idle state 2 (OC2N output). Please refer to the OC1NIS bit.                                                                                                                                                                         |  |
| Bit 10 | OC2IS  | rw   | Output idle state 2 (OC2 output). Please refer to the OC1IS bit.                                                                                                                                                                           |  |
| Bit 9  | OC1NIS | rw   | Output idle state 1 (OC1N output)<br>0: When MOEN = 0, OC1N = 0 after dead-time.<br>1: When MOEN = 0, OC1N = 1 after dead-time.<br><i>Note: This bit cannot be changed if the LOCKC bit (TMRx_BRKDT register) level 1, 2, or 3 is set.</i> |  |
| Bit 8  | OC1IS  | rw   | Output idle state 1 (OC1 output)                                                                                                                                                                                                           |  |



|         | 1          | 1  |                                                                       |
|---------|------------|----|-----------------------------------------------------------------------|
|         |            |    | 0: When MOEN = 0, if OC1N is done, $OC1 = 0$ after dead-              |
|         |            |    | time. 1: When MOEN = 0, if OC1N is done, $OC1 = 1$ after              |
|         |            |    | dead-time.                                                            |
|         |            |    | <i>Note: This bit cannot be changed if the LOCKC bit (TMRx_ BRKDT</i> |
|         |            |    | register) level 1, 2, or 3 is set.                                    |
|         |            |    | TI1 selection                                                         |
|         |            |    | 0: TMRx_CH1 pin is connected to TI1 input.                            |
| Bit 7   | TI1SEL     | rw | 1: TMRx_CH1, TMRx_CH2, and TMRx_CH3 pins are connected                |
|         |            |    | to the TI1 input after XORed.                                         |
|         |            |    | Master mode selection                                                 |
|         |            |    | The 3 bits select the synchronization information (TRGO) to be        |
|         |            |    | sent from master mode to slave timers. The possible                   |
|         |            |    | combinations are as follows:                                          |
|         |            |    | 000: Reset – The UEVG bit in the TMRx_EVEG register is used           |
|         |            |    | as trigger output (TRGO). If the reset is generated by the trigger    |
|         |            |    | input (slave mode controller is in reset mode), the signal on         |
|         |            |    | TRGO is delayed compared with the actual reset.                       |
|         |            |    | 001: Enable – The counter enable signal, CNT_EN, is used as           |
|         |            |    | trigger output (TRGO). It is useful to start several timers at the    |
|         |            |    | same time or to control a window in which a slave timer is            |
| Bit 6:4 | MMSEL[2:0] | rw | enabled. The counter enable signal is generated by a logic OR         |
|         |            |    | between CNTEN control bit and the trigger input signal in gated       |
|         |            |    | mode.                                                                 |
|         |            |    | When the counter enable signal is controlled by the trigger           |
|         |            |    | input, there is a delay on TRGO, unless the master/slave mode         |
|         |            |    | is selected (Please refer to the MSMODE bit description in the        |
|         |            |    | TMRx_SMC register).                                                   |
|         |            |    | 010: Update – The update event is selected as trigger output          |
|         |            |    | (TRGO). For instance, a master timer can be used as a prescaler       |
|         |            |    | for a slave timer.                                                    |
|         |            |    | 011: Compare Pulse – After a capture or a compare match               |
|         |            |    | occurs, the trigger output sends a positive pulse (TRGO) when         |
|         |            |    | willen                                                                |



| -     |       |    | 1                                                                   |  |  |
|-------|-------|----|---------------------------------------------------------------------|--|--|
|       |       |    | the C1IF flag is to be set (even if it is already high).            |  |  |
|       |       |    | 100: Compare – OC1REF signal is used as trigger output              |  |  |
|       |       |    | (TRGO).                                                             |  |  |
|       |       |    | 101: Compare – OC2REF signal is used as trigger output              |  |  |
|       |       |    | (TRGO).                                                             |  |  |
|       |       |    | 110: Compare – OC3REF signal is used as trigger output              |  |  |
|       |       |    | (TRGO).                                                             |  |  |
|       |       |    | 111: Compare – OC4REF signal is used as trigger output              |  |  |
|       |       |    | (TRGO).                                                             |  |  |
|       |       |    | Capture/Compare DMA selection                                       |  |  |
| Bit 3 | CDSEL | rw | 0: CCx DMA request is sent when CCx event occurs.                   |  |  |
|       |       |    | 1: CCx DMA request is sent when update event occurs.                |  |  |
|       |       |    | Capture/compare control update selection                            |  |  |
|       | CUSEL | rw | 0: When capture/compare control bits are preloaded (CPC =           |  |  |
|       |       |    | 1), they are updated only by setting the HALL bit.                  |  |  |
|       |       |    | 1: When capture/compare control bits are preloaded (CPC =           |  |  |
| Bit 2 |       |    | 1), they are updated by setting the HALL bit or a rising edge       |  |  |
|       |       |    | on TRGI.                                                            |  |  |
|       |       |    | <i>Note: This bit only acts on channels that have complementary</i> |  |  |
|       |       |    | output.                                                             |  |  |
| Bit 1 | _     | _  | Reserved. Always read as 0.                                         |  |  |
|       |       |    | Capture/compare preloaded control                                   |  |  |
|       |       |    | 0: The CxEN, CxNEN, and OCxMODE bits are not preloaded.             |  |  |
|       |       |    | 1: The CxEN, CxNEN and OCxMODE bits are not preloaded.              |  |  |
| Bit 0 |       |    | After being written, they are updated only when a HALL event        |  |  |
|       | CPC   | rw | occurs (the HALL bit is set or a rising edge is detected on         |  |  |
|       |       |    |                                                                     |  |  |
|       |       |    | TRGI, depending on the CUSEL bit).                                  |  |  |
|       |       |    | Note: This bit only acts on channels that have complementary        |  |  |
|       |       |    | output.                                                             |  |  |



### 10.4.4.3 TMR1 and TMR8 Slave Mode Control Register

### (TMRx\_SMC)

Address offset: 0x08

| Bit       | Name     | Туре | Description                                                      |  |  |
|-----------|----------|------|------------------------------------------------------------------|--|--|
|           |          |      | External trigger polarity                                        |  |  |
|           |          |      | This bit selects whether ETR or inverted ETR is used for trigger |  |  |
| Bit 15    | ETRGP    | rw   | operations.                                                      |  |  |
|           |          |      | 0: ETR is non-inverted and active at high level or rising edge.  |  |  |
|           |          |      | 1: ETR is inverted and active at low level or falling edge.      |  |  |
|           |          |      | External clock enable                                            |  |  |
|           |          |      | This bit enables external clock mode 2.                          |  |  |
|           |          |      | 0: External clock mode 2 is disabled                             |  |  |
|           |          |      | 1: External clock mode 2 is enabled. The counter is clocked by   |  |  |
|           | ECLKEN   | rw   | any active edge on the ETRF signal.                              |  |  |
|           |          |      | Note 1: Setting the ECLKEN bit has the same effect as selecting  |  |  |
| Bit 14    |          |      | external clock mode 1 with TRGI connected to ETRF (SMSEL =       |  |  |
|           |          |      | 111 and TRGSEL = 111).                                           |  |  |
|           |          |      | Note 2: It is possible to simultaneously use external clock mode |  |  |
|           |          |      | 2 with the following slave modes: reset mode, gated mode, and    |  |  |
|           |          |      | trigger mode. Nevertheless, TRGI must not be connected to        |  |  |
|           |          |      | ETRF in this case (TRGSEL bits must not be 111).                 |  |  |
|           |          |      | Note 3: If external clock mode 1 and external clock mode 2 are   |  |  |
|           |          |      | enabled at the same time, the external clock input is ETRF.      |  |  |
|           |          | rw   | External trigger divide                                          |  |  |
| Bit 13:12 | ETD[1:0] |      | External trigger signal ETRP frequency must be 1/4 of            |  |  |
|           |          |      | TMRxCLK frequency at most. A prescaler can be used to            |  |  |
|           |          |      | reduce ETRP frequency when inputting faster external clocks.     |  |  |
|           |          |      | 00: Prescaler is OFF.                                            |  |  |
|           |          |      | 01: ETRP frequency is divided by 2. 10: ETRP frequency is        |  |  |



|          |             |    | divided by 4. 11: ETRP frequency is divided by 8.                    |
|----------|-------------|----|----------------------------------------------------------------------|
|          |             |    | External trigger filter                                              |
|          |             |    | The bits define the frequency used to sample TETRP signal and        |
|          |             |    | the length of ETRP digital filter. In fact, the digital filter is an |
|          |             |    | event counter which records N consecutive events that are            |
|          |             |    | needed to generate a transition on the output:                       |
|          |             |    | 0000: No filter, sampling is done at $f_{\text{DTS}}$                |
|          |             |    | 0001: fsampling= fck_int, N= 2                                       |
|          |             |    | 0010: $f_{SAMPLING} = f_{CK_INT}$ , $N = 4$                          |
|          |             |    | 0011: fsampling= fck_int, N= 8                                       |
|          |             |    | 0100: $f_{SAMPLING} = f_{DTS}/2, N = 6$                              |
| Bit 11:8 | ETDF[3:0]   | rw | 0101: $f_{SAMPLING} = f_{DTS}/2, N = 8$                              |
|          |             |    | 0110: $f_{SAMPLING} = f_{DTS}/4, N = 6$                              |
|          |             |    | 0111: fsampling = fdts/4, N= 8                                       |
|          |             |    | 1000: $f_{SAMPLING} = f_{DTS}/8$ , N = 6                             |
|          |             |    | 1001: fsampling = fdts/8, N = 8                                      |
|          |             |    | 1010: $f_{SAMPLING} = f_{DTS}/16$ , N = 5                            |
|          |             |    | 1011: $f_{SAMPLING} = f_{DTS}/16$ , N = 6                            |
|          |             |    | 1100: $f_{SAMPLING} = f_{DTS}/16$ , N = 8                            |
|          |             |    | 1101: $f_{SAMPLING} = f_{DTS}/32, N = 5$                             |
|          |             |    | 1110: $f_{SAMPLING} = f_{DTS}/32, N = 6$                             |
|          |             |    | 1111: fsampling = fdts/32, N = 8                                     |
|          |             | rw | Master/Slave mode                                                    |
|          |             |    | 0: No effect                                                         |
| Bit 7    | MSMODE      |    | 1: The event on the trigger input (TRGI) is delayed to allow a       |
| Dit 7    | MSMODE      |    | perfect synchronization between the current timer and its slaves     |
| Bit 6:4  |             |    | (through TRGO). It is useful when synchronizing several timers       |
|          |             |    | on a single external event.                                          |
|          |             |    | Trigger selection                                                    |
|          | TRGSEL[2:0] | rw | The bits select the trigger input used to synchronize the            |
|          |             |    | counter.                                                             |
|          |             |    | 000: Internal Trigger 0 (ITR0)                                       |
|          |             | •  | ·                                                                    |



|         |            |    | 001: Internal Trigger 1 (ITR1)                                     |
|---------|------------|----|--------------------------------------------------------------------|
|         |            |    | 010: Internal Trigger 2 (ITR2)                                     |
|         |            |    | 011: Internal Trigger (ITR3)                                       |
|         |            |    | 100: TI1 Edge Detector (TI1F_ED)                                   |
|         |            |    | 101: Filtered Timer Input 1 (TI1FP1)                               |
|         |            |    | 110: Filtered Timer Input 2 (TI2FP2)                               |
|         |            |    | 111: External Trigger Input (ETRF)                                 |
|         |            |    | Please refer to Table 10-8 for the details on ITRx.                |
|         |            |    | Note: These bits must be changed only when they are not            |
|         |            |    | used (e.g. when SMSEL = 000) to avoid wrong edge                   |
|         |            |    | detections at transitions.                                         |
| Bit 3   | -          | -  | Reserved. Always read as 0.                                        |
|         |            |    | Slave mode selection                                               |
|         |            | rw | When external signals are selected, the active edge of the         |
|         |            |    | trigger signal (TRGI) is relevant to the selected external input   |
|         |            |    | polarity (Please refer to input control register and control       |
|         |            |    | register description.)                                             |
|         |            |    | 000: Slave mode is disabled - If $CNTEN = 1$ , the prescaler is    |
|         |            |    | clocked directly by the internal clock.                            |
|         |            |    | 001: Encoder mode 1 - Counter counts up/down on TI1FP1             |
|         |            |    | edge depending on TI2FP2 level.                                    |
|         |            |    | 010: Encoder mode 2 - Counter counts up/down on TI2FP2             |
| Bit 2:0 | SMSEL[2:0] |    | edge depending on TI1FP1 level.                                    |
|         |            |    | 011: Encoder mode 3 - Counter counts up/down on both               |
|         |            |    | TI1FP1 and TI2FP2 edges depending on the level of the other        |
|         |            |    | input.                                                             |
|         |            |    | 100: Reset Mode - Rising edge of the selected trigger input        |
|         |            |    | (TRGI) reinitializes the counter and generates an update           |
|         |            |    | register signal.                                                   |
|         |            |    | 101: Gated Mode - The counter clock is enabled when the            |
|         |            |    | trigger input (TRGI) is high. The counter stops (but is not reset) |
|         |            |    | once the trigger becomes low. Both start and stop of the counter   |
|         |            |    |                                                                    |



|  | are controlled.                                                 |
|--|-----------------------------------------------------------------|
|  | 110: Trigger Mode - The counter starts at a rising edge of the  |
|  | trigger input TRGI (but it is not reset). Only the start of the |
|  | counter is controlled.                                          |
|  | 111: External Clock Mode 1 - Rising edges of the selected       |
|  | trigger input (TRGI) clocks the counter.                        |
|  | Note: The gated mode must not be used if TI1F_EN is selected    |
|  | as the trigger input (TRGSEL = 100). This is because TI1F_ED    |
|  | outputs 1 pulse for each transition on TI1F, whereas the gated  |
|  | mode checks the level of the trigger input signal.              |

#### Table 10-8 TMRx Internal Trigger Connection

| Slave Timer | ITR0 (TRGSEL = | ITR1 (TRGSEL = | ITR2 (TRGSEL = | ITR3 (TRGSEL = |
|-------------|----------------|----------------|----------------|----------------|
|             | 000)           | 001)           | 010)           | 011)           |
| TMR1        | TMR5           | TMR2           | TMR3           | TMR4           |
| TMR8        | TMR1           | TMR2           | TMR4           | TMR5           |
| Reserved    | TMR8           | TMR2           | TMR4           | TMR5           |

## 10.4.4.4 TMR1 and TMR8 DMA/Interrupt Enable Register (TMRx\_DIE)

Address offset: 0x0C

| Bit    | Name   | Туре | Description                         |  |  |  |
|--------|--------|------|-------------------------------------|--|--|--|
| Bit 15 | -      | -    | Reserved. Always read as 0.         |  |  |  |
|        |        |      | Trigger DMA request enable          |  |  |  |
| Bit 14 | TRGDE  | rw   | 0: Trigger DMA request is disabled. |  |  |  |
|        |        |      | 1: Trigger DMA request is enabled.  |  |  |  |
|        |        |      | HALL DMA request enable             |  |  |  |
| Bit 13 | HALLDE | rw   | 0: HALL DMA request is disabled.    |  |  |  |
|        |        |      | 1: HALL DMA request is enabled.     |  |  |  |



|        |        |    | Capture/Compare 4 DMA request enable          |
|--------|--------|----|-----------------------------------------------|
| Bit 12 | C4DE   | rw | 0: Capture/Compare 4 DMA request is disabled. |
|        |        |    | 1: Capture/Compare 4 DMA request is enabled.  |
|        |        |    | Capture/Compare 3 DMA request enable          |
| Bit 11 | C3DE   | rw | 0: Capture/Compare 3 DMA request is disabled. |
|        |        |    | 1: Capture/Compare 3 DMA request is enabled.  |
|        |        |    | Capture/Compare 2 DMA request enable          |
| Bit 10 | C2DE   | rw | 0: Capture/Compare 2 DMA request is disabled. |
|        |        |    | 1: Capture/Compare 2 DMA request is enabled.  |
|        |        |    | Capture/Compare 1 DMA request enable          |
| Bit 9  | C1DE   | rw | 0: Capture/Compare 1 DMA request is disabled. |
|        |        |    | 1: Capture/Compare 1 DMA request is enabled.  |
|        |        |    | Update DMA request enable                     |
| Bit 8  | UEVDE  | rw | 0: Update DMA request is disabled.            |
|        |        |    | 1: Update DMA request is enabled.             |
|        |        |    | Break interrupt enable                        |
| Bit 7  | BRKIE  | rw | 0: Break interrupt is disabled.               |
|        |        |    | 1: Break interrupt is enabled.                |
|        |        |    | Trigger interrupt enable                      |
| Bit 6  | TRGIE  | rw | 0: Trigger interrupt is disabled.             |
|        |        |    | 1: Trigger interrupt is enabled.              |
|        |        |    | HALL interrupt enable                         |
| Bit 5  | HALLIE | rw | 0: HALL interrupt is disabled.                |
|        |        |    | 1: HALL interrupt is enabled.                 |
|        |        |    | Capture/Compare 4 interrupt enable            |
| Bit 4  | C4IE   | rw | 0: Capture/Compare 4 interrupt is disabled.   |
|        |        |    | 1: Capture/Compare 4 interrupt is enabled.    |
| Bit 3  | C3IE   | rw | Capture/Compare 3 interrupt enable            |
|        |        |    |                                               |



Hangzhou Vango Technologies, Inc.

|       |       |    | 0: Capture/Compare 3 interrupt is disabled.<br>1: Capture/Compare 3 interrupt is enabled.                                       |
|-------|-------|----|---------------------------------------------------------------------------------------------------------------------------------|
| Bit 2 | C2IE  | rw | Capture/Compare 2 interrupt enable<br>0: Capture/Compare 2 interrupt is disabled.<br>1: Capture/Compare 2 interrupt is enabled. |
| Bit 1 | C1IE  | rw | Capture/Compare 1 interrupt enable<br>0: Capture/Compare 1 interrupt is disabled.<br>1: Capture/Compare 1 interrupt is enabled. |
| Bit 0 | UEVIE | rw | Update interrupt enable<br>0: Update interrupt is disabled.<br>1: Update interrupt is enabled.                                  |

### 10.4.4.5 TMR1 and TMR8 Status Register (TMRx\_STS)

Address offset: 0x10

| Bit       | Name | Туре | Description                                                                                                                                                                                                                                                                |
|-----------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:13 | -    | -    | Reserved. Always read as 0.                                                                                                                                                                                                                                                |
| Bit 12    | C4OF | rw   | Capture/Compare 4 overcapture flag Please refer to C1OF description.                                                                                                                                                                                                       |
| Bit 11    | C3OF | rw   | Capture/Compare 3 overcapture flag Please refer to C1OF description.                                                                                                                                                                                                       |
| Bit 10    | C2OF | rw   | Capture/Compare 2 overcapture flag Please refer to C1OF description.                                                                                                                                                                                                       |
| Bit 9     | C10F | rw   | Capture/Compare 1 overcapture flag<br>This flag is set by hardware only when the corresponding<br>channel is configured as input capture mode. It is cleared by<br>writing '0'.<br>0: No overcapture is detected.<br>1: When the counter value is captured to the TMRx_CC1 |



|        |                                         | register, C1IF flag is already set.                            |
|--------|-----------------------------------------|----------------------------------------------------------------|
| -      | -                                       | Reserved. Always read as 0.                                    |
|        |                                         | Break interrupt flag                                           |
|        |                                         | This flag is set by hardware once the break input goes active. |
| BRKIF  | rw                                      | It can be cleared by software if the break input is inactive.  |
|        |                                         | 0: No break event occurs.                                      |
|        |                                         | 1: An active level is detected on the break input.             |
|        |                                         | Trigger interrupt flag                                         |
|        |                                         | This flag is set by hardware on trigger event (When the slave  |
|        |                                         | mode controller is in all modes except for gated mode, active  |
| TRGIF  | rw                                      | edge is detected on TRGI input, or any edge in the gated       |
|        |                                         | mode). It is cleared by software.                              |
|        |                                         | 0: No trigger event occurs.                                    |
|        |                                         | 1: Trigger interrupt is pending.                               |
|        |                                         | HALL interrupt flag                                            |
|        |                                         | This flag is set by hardware on HALL event (when               |
| HALLIF |                                         | capture/compare control bits: CxEN, CxNEN, OCxMODE are         |
|        | rw                                      | updated). It is cleared by software.                           |
|        |                                         | 0: No HALL event occurs.                                       |
|        |                                         | 1: HALL interrupt is pending.                                  |
| C4IF   | rw                                      | Capture/Compare 4 interrupt flag Please refer to C1IF          |
|        |                                         | description.                                                   |
|        |                                         | Capture/Compare 3 interrupt flag Please refer to C1IF          |
| C3IF   | rw                                      | description.                                                   |
|        |                                         | Capture/Compare 2 interrupt flag Please refer to C1IF          |
| C2IF   | rw                                      | description.                                                   |
|        |                                         | Capture/Compare 1 interrupt flag                               |
| C1IF   | rw                                      | If channel CC1 is configured as output mode:                   |
|        |                                         | This flag is set by hardware when the counter value matches    |
|        |                                         | the compare value, but not in center-aligned mode (Please      |
|        |                                         | refer to the CMSEL bits in the TMRx_CTRL1). It is cleared by   |
|        | TRGIF<br>HALLIF<br>C4IF<br>C3IF<br>C2IF | TRGIF rw C4IF rw C2IF rw                                       |



|       |       |  | software.                                                        |
|-------|-------|--|------------------------------------------------------------------|
|       |       |  | 0: No match                                                      |
|       |       |  | 1: The TMRx_CNT value matches the TMRx_CC1 value.                |
|       |       |  | When the contents of TMRx_CC1 are greater than the contents      |
|       |       |  | of TMRx_AR, the C1IF bit goes high on the counter overflow in    |
|       |       |  | upcounting and up/down-counting modes, or on underflow in        |
|       |       |  | downcounting mode.                                               |
|       |       |  | If channel CC1 is configured as input mode:                      |
|       |       |  | This bit is set by hardware on a capture. It is cleared by       |
|       |       |  | software or by reading the TMRx_CC1 register.                    |
|       |       |  | 0: No input capture occurs.                                      |
|       |       |  | 1: The counter value is captured to the TMRx_CC1 register (An    |
|       |       |  | edge which matches the selected polarity is detected on IC1).    |
|       |       |  | Update interrupt flag                                            |
|       |       |  | This bit is set by hardware on an update event. It is cleared by |
|       |       |  | software.                                                        |
|       |       |  | 0: No update event occurs.                                       |
|       |       |  | 1: Update interrupt is pending. This bit is set by hardware      |
|       |       |  | when the registers are updated:                                  |
|       | UEVIF |  | - If UEVDIS = 0 in the TMRx_CTRL1 register, when repetition      |
| Bit 0 |       |  | counter value overflows or underflows (An update event is        |
|       |       |  | generated when the repetition counter $= 0$ ).                   |
|       |       |  | - If UEVDIS = 0 and UEVRS = 0 in the TMRx_CTRL1 register, an     |
|       |       |  | update event is generated when UEVG = 1 in the TMRx_EVEG         |
|       |       |  | register (when the counter CNT is reinitialized by software).    |
|       |       |  | - If UEVDIS = 0 and UEVRS = 0 in the TMRx_CTRL1 register,        |
|       |       |  | when the counter CNT is reinitialized by trigger events (Please  |
|       |       |  | refer to <u>Section 10.4.4.3</u> ).                              |

### 10.4.4.6 TMR1 and TMR8 Event Generation Register

### (TMRx\_EVEG)

Address offset: 0x14



| Bit      | Name  | Туре | Description                                                                                                                                                                                                                                                                                                                               |
|----------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:8 | -     | -    | Reserved. Always read as 0.                                                                                                                                                                                                                                                                                                               |
| Bit 7    | BRKG  | rw   | <ul> <li>Break generation</li> <li>This bit is set by software to generate a break event. It is</li> <li>cleared automatically by hardware.</li> <li>0: No action</li> <li>1: A break event is generated. At this time, MOEN = 0 and</li> <li>BRKIF = 1.The corresponding interrupt and DMA are</li> <li>generated if enabled.</li> </ul> |
| Bit 6    | TRGG  | rw   | Trigger generation<br>This bit is set by software to generate a trigger event. It is<br>cleared automatically by hardware.<br>0: No action<br>1: TRGIF = 1 in the TMRx_STS register, the corresponding<br>interrupt and DMA is generated if enabled.                                                                                      |
| Bit 5    | HALLG | rw   | Capture/Compare control update generation<br>This bit is set by software. It is cleared automatically by<br>hardware.<br>0: No action<br>1: When CPC = 1, the CxEN, CxNEN, and OCxMODE bits are<br>allowed to be updated.<br><i>Note: This bit only acts on channels that have complementary</i><br><i>output.</i>                        |
| Bit 4    | C4G   | rw   | Capture/compare 4 generation Please refer to C1G description.                                                                                                                                                                                                                                                                             |
| Bit 3    | C3G   | rw   | Capture/compare 3 generation Please refer to C1G description.                                                                                                                                                                                                                                                                             |
| Bit 2    | C2G   | rw   | Capture/compare 2 generation Please refer to C1G description.                                                                                                                                                                                                                                                                             |
| Bit 1    | C1G   | rw   | Capture/compare 1 generation<br>This bit is set by software to generate a capture/compare<br>event. It is cleared automatically by hardware.                                                                                                                                                                                              |



|       |      |    | 0: No action                                                      |
|-------|------|----|-------------------------------------------------------------------|
|       |      |    | 1: A capture/compare event is generated on channel 1 CC1:         |
|       |      |    | If channel CC1 is configured as output:                           |
|       |      |    | Set C1IF = 1. The corresponding interrupt and DMA request is      |
|       |      |    | generated if enabled.                                             |
|       |      |    | If channel CC1 is configured as input:                            |
|       |      |    | The current value of the counter is captured to the TMRx_CC1      |
|       |      |    | register. Set $C1IF = 1$ . The corresponding interrupt and DMA    |
|       |      |    | request is generated if enabled. If C1IF is already `1', set C1OF |
|       |      |    | = 1.                                                              |
|       |      |    | Update generation                                                 |
|       |      |    | This bit can be set by software, and it is automatically cleared  |
|       | UEVG | rw | by hardware.                                                      |
|       |      |    | 0: No action                                                      |
| Bit 0 |      |    | 1: Re-initialize the counter and generate an update. Please       |
|       |      |    | note that the prescaler counter is also cleared, but the          |
|       |      |    | prescaler ratio is not affected. The counter is cleared if the    |
|       |      |    | center-aligned mode is selected, or if DIR = 0 (upcounting),      |
|       |      |    | else it takes the TMRx_AR value if DIR = 1 (downcounting).        |

## 10.4.4.7 TMR1 and TMR8 Capture/Compare Mode Register 1 (TMRx\_CCM1)

Address offset: 0x18

Reset value: 0x0000

The channels can be used in input (capture mode) or in output (compare mode). The direction of a channel is defined by the corresponding CxSEL bits. All the other bits of this register have different functions in input and output modes. For a given bit, OCxx describes its function when the channel is in output mode, while ICxx describes its function when the channel is in input mode. Attention must be given to the fact that the same bit can have different definitions for the input stage and for the output stage.





| Bit            | Name         | Туре | Description                                                      |
|----------------|--------------|------|------------------------------------------------------------------|
| Bit 15         | OC2DIS       | rw   | Output compare 2 clear enable                                    |
| Bit 14:12      | OC2MODE[2:0] | rw   | Output compare 2 mode                                            |
| Bit 11         | OC2PEN       | rw   | Output compare 2 preload enable                                  |
| Bit 10         | OC2FEN       | rw   | Output compare 2 fast enable                                     |
|                |              |      | Capture/Compare 2 selection                                      |
|                |              |      | This bit defines the channel direction (input/output), and the   |
|                |              |      | selection of input pin: 00: CC2 channel is configured as         |
|                |              |      | output.                                                          |
|                |              |      | 01: CC2 channel is configured as input, IC2 is mapped on TI2.    |
| Bit 9:8        | C2SEL[1:0]   | rw   | 10: CC2 channel is configured as input, IC2 is mapped on TI1.    |
|                |              |      | 11: CC2 channel is configured as input, IC2 is mapped on TRC.    |
|                |              |      | This mode works only when the internal trigger input is selected |
|                |              |      | (by the TRGSEL bit in the TMRx_SMC register).                    |
|                |              |      | Note: C2SEL can be written only when the channel is disabled     |
|                |              |      | (C2NEN = 0 in the TMRx_CCE register).                            |
|                |              | rw   | Output compare 1 clear enable                                    |
|                | 001010       |      | 0: OC1REF is not affected by ETRF input.                         |
| Bit 7          | OC1DIS       |      | 1: Once high level is detected on ETRF input, clear OC1REF =     |
|                |              |      | 0.                                                               |
|                |              |      | Output compare 1 mode                                            |
|                |              | rw   | The bits define the behavior of the output reference signal,     |
|                |              |      | OC1REF, and OC1REF determines the OC1 and OC1N values.           |
|                |              |      | OC1REF is active high, while active levels of OC1 and OC1N are   |
| Bit 6:4        |              |      | determined by the C1P and C1NP bits.                             |
| <b>ΔΙΙ Ο:4</b> | OC1MODE[2:0] |      | 000: Frozen. The comparison between the output compare           |
|                |              |      | register TMRx_CC1 and the counter TMRx_CNT has no effect on      |
|                |              |      | OC1REF.                                                          |
|                |              |      | 001: Set channel 1 to active level on match. OC1REF is forced    |
|                |              |      | high when the value of the counter TMRx_CNT matches the          |



|       |        | ī  |                                                               |
|-------|--------|----|---------------------------------------------------------------|
|       |        |    | capture/compare register1 (TMRx_CC1).                         |
|       |        |    | 010: Set channel 1 to inactive level on match. OC1REF is      |
|       |        |    | forced low when the value of the counter TMRx_CNT matches     |
|       |        |    | the capture/compare register1 (TMRx_CC1).                     |
|       |        |    | 011: Toggle. Toggle OC1REF level whenTMRx_CC1 =               |
|       |        |    | TMRx_CNT. 100: Force inactive level. OC1REF is forced low.    |
|       |        |    | 101: Force active level. OC1REF is forced high.               |
|       |        |    | 110: PWM mode 1 $-$ In upcounting, channel 1 is active once   |
|       |        |    | TMRx_CNT < TMRx_CC1, else inactive; in downcounting,          |
|       |        |    | channel 1 is inactive once TMRx_CNT > TMRx_CC1 (OC1REF =      |
|       |        |    | 0), else active (OC1REF = 1).                                 |
|       |        |    | 111: PWM mode 2—In upcounting, channel 1 is inactive once     |
|       |        |    | TMRx_CNT < TMRx_CC1, else active; in downcounting,            |
|       |        |    | channel 1 is active once TMRx_CNT > TMRx_CC1, else            |
|       |        |    | inactive.                                                     |
|       |        |    | Note 1: Once the LOCK level is set to 3 (the LOCKC bit in the |
|       |        |    | TMRx_BRKDT register) and C1SEL = 00 (this channel             |
|       |        |    | configured as output), the bit cannot be changed.             |
|       |        |    | Note 2: In PWM mode 1 or PWM mode 2, OC1REF level changes     |
|       |        |    | only when the comparison result changes or when the output    |
|       |        |    | compare mode switches from frozen mode to PWM mode .          |
|       |        |    | Output compare 1 preload enable                               |
|       |        |    | 0: Preload function of TMRx_CC1 is disabled. TMRx_CC1 can     |
|       |        |    | be written at any time, and the new value takes effect        |
|       |        |    | immediately.                                                  |
|       |        |    | 1: Preload function of TMRx_CC1 is enabled. Read/Write        |
| Bit 3 | OC1PEN | rw | operations only access the preload register. TMRx_CC1         |
|       |        |    | preload value is sent to the active register at each update   |
|       |        |    | event.                                                        |
|       |        |    | Note 1: Once the LOCK level is set to 3 (the LOCKC bit in the |
|       |        |    | TMRx_BRKDT register) and C1SEL = 00 (this channel             |
|       |        |    | configured as output), the bit cannot be changed.             |
| •     | •      |    |                                                               |



|         |            |    | Note 2: The PWM mode can be used without validating the preload                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |            |    | register only in one-pulse mode (OPMODE = `1´ in the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         |            |    | TMRx_CTRL1 register). Else, the behavior is not guaranteed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 2   | OC1FEN     | rw | Output compare 1 fast enable<br>This bit is used to accelerate the CC output's response to<br>trigger the input event.<br>0: CC1 behaves normally with the counter and CC1 values<br>even when the trigger is ON. When an active edge occurs on<br>the trigger input, the minimum delay to activate CC1 output is<br>5 clock cycles.<br>1: An active edge on the trigger input acts like a compare<br>match. Therefore, OC is set to the compare level which is<br>irrelevant to the result of the comparison. Delay to sample the<br>trigger input and to activate CC1 output is reduced to 3 clock<br>cycles.<br>This bit only acts when channel is configured as PWM1or PWM2<br>mode. |
| Bit 1:0 | C1SEL[1:0] | rw | Capture/Compare 1 selection<br>The bits define the channel direction (input/output), and input<br>pin selection:<br>00: CC1 channel is configured as output.<br>01: CC1 channel is configured as input, IC1 is mapped on TI1.<br>10: CC1 channel is configured as input, IC1 is mapped on TI2.<br>11: CC1 channel is configured as input, IC1 is mapped on TRC.<br>This mode works only when the internal trigger input is selected<br>(by the TRGSEL bit in the TMRx_SMC register).<br><i>Note: C1SEL can be written only when the channel is disabled</i><br><i>(C1EN = '0' in the TMRx_CCE register).</i>                                                                             |

#### Input capture mode

| Bit       | Name       | Туре  | Description                  |           |
|-----------|------------|-------|------------------------------|-----------|
| Bit 15:12 | IC2DF[3:0] | rw    | Input capture 2 filter       |           |
| Mango +   |            | Hangz | hou Vango Technologies, Inc. | 414 / 782 |

| Bit 11:10 | IC2DIV[1:0] | rw | Input capture 2 prescaler                                            |
|-----------|-------------|----|----------------------------------------------------------------------|
|           |             |    |                                                                      |
| Bit 9:8   | C2SEL[1:0]  | rw | Capture/Compare 2 selection                                          |
|           |             |    | The bits define the channel direction (input/output), and input      |
|           |             |    | pin selection:                                                       |
|           |             |    | 00: CC2 channel is configured as output.                             |
|           |             |    | 01: CC2 channel is configured as input, IC2 is mapped on TI2.        |
|           |             |    | 10: CC2 channel is configured as input, IC2 is mapped on TI1.        |
|           |             |    | 11: CC2 channel is configured as input, IC2 is mapped on TRC.        |
|           |             |    | This mode works only when the internal trigger input is selected     |
|           |             |    | (by the TRGSEL bit in the TMRx_SMC register).                        |
|           |             |    | Note: C2SEL can be written only when the channel is disabled         |
|           |             |    | (C2EN = '0' in the TMRx_CCE register).                               |
| Bit 7:4   | IC1D [3:0]  | rw | External trigger filter                                              |
|           |             |    | The bits define the frequency used to sample ETRP signal and         |
|           |             |    | the length of ETRP digital filter. In fact, the digital filter is an |
|           |             |    | event counter which records N consecutive events that are            |
|           |             |    | needed to generate a transition on the output:                       |
|           |             |    | 0000: No filter, sampling is done at fors                            |
|           |             |    | 0001: fsampling= fck_int, N= 2                                       |
|           |             |    | 0010: fsampling= fck_int, N= 4                                       |
|           |             |    | 0011: fsampling= fck_int, N= 8                                       |
|           |             |    | 0100: $f_{SAMPLING} = f_{DTS}/2, N = 6$                              |
|           |             |    | 0101: $f_{SAMPLING} = f_{DTS}/2, N = 8$                              |
|           |             |    | 0110: $f_{SAMPLING} = f_{DTS}/4$ , N = 6                             |
|           |             |    | 0111: $f_{SAMPLING} = f_{DTS}/4$ , N = 8                             |
|           |             |    | 1000: $f_{SAMPLING} = f_{DTS} / 8$ , N = 6                           |
|           |             |    | 1001: $f_{SAMPLING} = f_{DTS}/8, N = 8$                              |
|           |             |    | 1010: $f_{SAMPLING} = f_{DTS}/16$ , N = 5                            |
|           |             |    | 1011: fsampling = fdts/16, N = 6                                     |
|           |             |    | $1100:f_{SAMPLING} = f_{DTS}/16, N = 8$                              |
|           |             |    | 1101: fsampling = fdts/32, N = 5                                     |
|           |             |    | . ,                                                                  |



|         |             |    | 1110: $f_{SAMPLING} = f_{DTS}/32$ , N = 6                        |
|---------|-------------|----|------------------------------------------------------------------|
|         |             |    | 1111: $f_{SAMPLING} = f_{DTS}/32$ , N = 8                        |
|         |             |    |                                                                  |
|         |             |    |                                                                  |
|         |             |    |                                                                  |
|         |             |    |                                                                  |
| Bit 3:2 | IC1DIV[1:0] | rw | Input capture 1 prescaler                                        |
|         |             |    | The bits define CC1 input (IC1) prescaler ratio.                 |
|         |             |    | Once C1EN = $0'$ (in the TMRx_CCE register), the prescaler is    |
|         |             |    | reset.                                                           |
|         |             |    | 00: No prescaler. Capture is done each time when an edge is      |
|         |             |    | detected on the capture input.                                   |
|         |             |    | 01: Capture is done once every 2 events.                         |
|         |             |    | 10: Capture is done once every 4 events                          |
|         |             |    | 11: Capture is done once every 8 events.                         |
| Bit 1:0 | C1SEL[1:0]  | rw | Capture/Compare 1 selection                                      |
|         |             |    | The bits define the channel direction (input/output), and input  |
|         |             |    | pin selection:                                                   |
|         |             |    | 00: CC1 channel is configured as output.                         |
|         |             |    | 01: CC1 channel is configured as input, IC1 is mapped on TI1.    |
|         |             |    | 10: CC1 channel is configured as input, IC1 is mapped on TI2.    |
|         |             |    | 11: CC1 channel is configured as input, IC1 is mapped on TRC.    |
|         |             |    | This mode works only when the internal trigger input is selected |
|         |             |    | (by the TRGSEL bit in the TMRx_SMC register).                    |
|         |             |    | Note: C1SEL can be written only when the channel is disabled     |
|         |             |    | (C1EN = '0' in the TMRx_CCE register).                           |
|         |             |    |                                                                  |

# 10.4.4.8 TMR1 and TMR8 Capture/Compare Mode Register 2 (TMRx\_CCM2)

Address offset: 0x1C



Please refer to the above-mentioned CCM1 registers description.

#### **Output compare mode**

| Bit       | Name         | Туре | Description                                                      |  |
|-----------|--------------|------|------------------------------------------------------------------|--|
| Bit 15    | OC4DIS       | rw   | Output compare 4 clear enable                                    |  |
| Bit 14:12 | OC4MODE[2:0] | rw   | Output compare 4 mode                                            |  |
| Bit 11    | OC4PEN       | rw   | Output compare 4 preload enable                                  |  |
| Bit 10    | OC4FEN       | rw   | Output compare 4 fast enable                                     |  |
| Bit 9:8   | C4SEL[1:0]   | rw   | Capture/Compare 4 selection                                      |  |
|           |              |      | The bits define the channel direction (input/output), and input  |  |
|           |              |      | pin selection:                                                   |  |
|           |              |      | 00: CC4 channel is configured as output.                         |  |
|           |              |      | 01: CC4 channel is configured as input, IC4 is mapped on TI4.    |  |
|           |              |      | 10: CC4 channel is configured as input, IC4 is mapped on TI3.    |  |
|           |              |      | 11: CC4 channel is configured as input, IC4 is mapped on TRC.    |  |
|           |              |      | This mode works only when the internal trigger input is selected |  |
|           |              |      | (by the TRGSEL bit in the TMRx_SMC register).                    |  |
|           |              |      | Note: CC4 can be written only when the channel is disabled       |  |
|           |              |      | (C4EN = '0' in the TMRx_CCE register).                           |  |
| Bit 7     | OC3DIS       | rw   | Output compare 3 clear enable                                    |  |
| Bit 6:4   | OC3MODE[2:0] | rw   | Output compare 3 mode                                            |  |
| Bit 3     | OC3PEN       | rw   | Output compare 3 preload enable                                  |  |
| Bit 2     | OC3FEN       | rw   | Output compare 3 fast enable                                     |  |
| Bit 1:0   | C3SEL[1:0]   | rw   | Capture/Compare 3 selection                                      |  |
|           |              |      | The bits define the channel direction (input/output), and input  |  |
|           |              |      | pin selection:                                                   |  |
|           |              |      | 00: CC3 channel is configured as output.                         |  |
|           |              |      | 01: CC3 channel is configured as input, IC3 is mapped on TI3.    |  |
|           |              |      | 10: CC3 channel is configured as input, IC3 is mapped on TI4.    |  |
|           |              |      | 11: CC3 channel is configured as input, IC3 is mapped on TRC.    |  |



|  | This mode works only when the internal trigger input is selected |
|--|------------------------------------------------------------------|
|  | (by the TRGSEL bit in the TMRx_SMC register).                    |
|  | Note: C3SEL can be written only when the channel is disabled     |
|  | (C3EN = '0' in the TMRx_CCE register).                           |
|  |                                                                  |

#### Input capture mode

| Bit       | Name        | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|-----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 15:12 | IC4DF[3:0]  | rw   | Input capture 4 filter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| Bit 11:10 | IC4DIV[1:0] | rw   | Input capture 4 prescaler                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| Bit 9:8   | C4SEL[1:0]  | rw   | Capture/Compare 4 selection<br>The bits define the channel direction (input/output), and input<br>pin selection:<br>00: CC4 channel is configured as output.<br>01: CC4 channel is configured as input, IC4 is mapped on TI4.<br>10: CC4 channel is configured as input, IC4 is mapped on TI3.<br>11: CC4 channel is configured as input, IC4 is mapped on TRC.<br>This mode works only when the internal trigger input is selected<br>(by the TRGSEL bit in the TMRx_SMC register).<br><i>Note: C4SEL can be written only when the channel is disabled</i><br><i>(C4EN = '0' in the TMRx_CCE register).</i> |  |
| Bit 7:4   | IC3DF[3:0]  | rw   | Input capture 3 filter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| Bit 3:2   | IC3DIV[1:0] | rw   | Input capture 3 prescaler                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| Bit 1:0   | C3SEL[1:0]  | rw   | Capture/Compare 3 selection<br>The bits define the channel direction (input/output), and input<br>pin selection:<br>00: CC3 channel is configured as output.<br>01: CC3 channel is configured as input, IC3 is mapped on TI3.<br>10: CC3 channel is configured as input, IC3 is mapped on TI4.<br>11: CC3 channel is configured as input, IC3 is mapped on TRC.<br>This mode works only when the internal trigger input is selected<br>(by the TRGSEL bit in the TMRx_SMC register).                                                                                                                         |  |



| Note: C3SEL can be written only when the channel is disabled |
|--------------------------------------------------------------|
| (C3EN = '0' in the TMRx_CCE register).                       |

## 10.4.4.9 TMR1 and TMR8 Capture/Compare Enable Register (TMRx\_CCE)

Address offset: 0x20

| Bit       | Name  | Туре | Description                                                                         |
|-----------|-------|------|-------------------------------------------------------------------------------------|
| Bit 15:14 | -     | -    | Reserved. Always read as 0.                                                         |
| Bit 13    | C4P:  | rw   | Capture/Compare 4 output polarity Please refer to C1P description.                  |
| Bit 12    | C4EN  | rw   | Capture/Compare 4 output enable Please refer to C1EN description.                   |
| Bit 11    | C3NP  | rw   | Capture/Compare 3 complementary output polarity Please refer to C1NP description.   |
| Bit 10    | C3NEN | rw   | Capture/Compare 3 complementary output enable Please refer to C1NEN description.    |
| Bit 9     | СЗР   | rw   | Capture/Compare 3 output polarity Please refer to C1P description.                  |
| Bit 8     | C3EN  | rw   | Capture/Compare 3 output enable Please refer to C1EN description.                   |
| Bit 7     | C2NP  | rw   | Capture/Compare 2 complementary output polarity Please refer to C1NP description.   |
| Bit 6     | C2NEN | rw   | Capture/Compare 2 complementary output enable Please refer<br>to C1NEN description. |
| Bit 5     | C2P   | rw   | Capture/Compare 2 output polarity Please refer to C1P description.                  |
| Bit 4     | C2EN  | rw   | Capture/Compare 2 output enable Please refer to C1EN                                |



|       |      |      | description.                                                           |
|-------|------|------|------------------------------------------------------------------------|
|       |      |      | Capture/Compare 1 complementary output polarity                        |
|       |      |      | CC1 channel is configured as output:                                   |
|       |      |      | 0: OC1N is active high.                                                |
|       |      |      | 1: OC1N is active low.                                                 |
| Bit 3 | C1NP | F14/ | CC1 channel is configured as input:                                    |
|       | CINF | rw   | C1NP is combined with C1P to define TI1FP1/TI2FP1 polarity             |
|       |      |      | (Please refer to C1P description).                                     |
|       |      |      | Note: This bit cannot be modified once LOCK level is set as $2'$       |
|       |      |      | or `3' (the LOCKC bits in the TMRx_BRKDT register) and C1SEL           |
|       |      |      | = 00 (channel is configured as output).                                |
|       |      |      | Capture/Compare 1 output polarity                                      |
|       |      |      | CC1 channel is configured as output:                                   |
|       |      |      | 0: OC1N is active high.                                                |
|       |      |      | 1: OC1N is active low.                                                 |
|       |      |      | CC1 channel is configured as input:                                    |
|       |      |      | The CC1NP/CC1P bits select TI1FP1 and TI2FP1 polarity signal           |
|       |      |      | as trigger or capture signal.                                          |
|       |      |      | 00: Not inverted/Rising edge. Circuit is sensitive to TIxFP1           |
| Bit 1 |      |      | rising edge (capture, reset in trigger, external clock or trigger      |
|       | C1P  | rw   | mode). TIxFP1 is not inverted (gated mode in trigger).                 |
|       |      |      | 01: Inverted/Falling edge. Circuit is sensitive to TIxFP1 falling      |
|       |      |      | edge (capture, reset in trigger, external clock or trigger             |
|       |      |      | mode). TIxFP1 is inverted (gated mode in trigger).                     |
|       |      |      | 10: Reserved                                                           |
|       |      |      | 11: Not inverted/Both edges. Circuit is sensitive to both              |
|       |      |      | TIxFP1 rising and falling edge (capture, reset in trigger,             |
|       |      |      | external clock or trigger mode). TIxFP1 is not inverted (gated         |
|       |      |      | mode in trigger).                                                      |
|       |      |      | <i>Note: This bit cannot be modified once LOCK level is set as '2'</i> |



| Bit 0C1ENCaptureCapture/Compare 1 output enableC21 channel is configured as output:<br>0: OFF - OC1 output is disabled. So OC1 output level<br>on the values of the MOEN, OSIMI, OSIMR, OC1IS, OC<br>and C1NEN bits.<br>1: ON - OC1 signal outputs on the corresponding output<br>and its output level outpu level depends on the values |          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| MOEN, OSIMI, OSIMR, OC1IS, OC1NIS, and C1NEN bit         CC1 channel is configured as input:         This bit determines whether the counter value can be         to TMRx_CC1 register.                                                                                                                                                  | of the   |
|                                                                                                                                                                                                                                                                                                                                          | captured |
|                                                                                                                                                                                                                                                                                                                                          | ts.      |

#### Table 10-9 Complementary Output Channel OCx and OCxN Control Bits with Break Function

|             | (            | Control B    | it          |                                                                     | Output State (Note)                                                 |                                                                         |
|-------------|--------------|--------------|-------------|---------------------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------|
| MOEN<br>bit | OSIMI<br>bit | OSIMR<br>bit | CxEN<br>bit | CxNEN<br>bit                                                        | OCx Output State                                                    | OCxN Output State                                                       |
|             |              | 0            | 0           | 0                                                                   | Output disabled<br>(not driven by the timer) OCx<br>= 0, OCx_EN = 0 | Output disabled<br>(not driven by the timer)<br>$OCxN = 0, OCxN_EN = 0$ |
| 1 X         | 0            | 0            | 1           | Output disabled<br>(not driven by the timer) OCx<br>= 0, OCx_EN = 0 | OCxREF + polarity, OCxN =<br>OCxREF xor CxNP,<br>OCxN_EN = 1        |                                                                         |
|             |              | 0            | 1           | 0                                                                   | OCxREF + polarity, OCx =<br>OCxREF xor CxP, OCx_EN = 1              | Output disabled<br>(not driven by the timer)<br>$OCxN = 0, OCxN_EN = 0$ |
|             |              | 0            | 1           | 1                                                                   | OCxREF + polarity+ dead-                                            | OCxREF inverted + polarity                                              |



|   |                       |   |   |   | time, OCx_EN = 1                                                                         | + dead-time, OCxN_EN = 1                                                         |
|---|-----------------------|---|---|---|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
|   |                       | 1 | 0 | 0 | Output disabled<br>(not driven by the timer) OCx<br>= CxP, OCx_EN = 0                    | Output disabled<br>(not driven by the timer)<br>OCxN = CxNP, OCxN_EN =<br>0      |
|   |                       | 1 | 0 | 1 | Off-state<br>(output enabled with inactive<br>state) OCx = CxP, OCx_EN = 1               | OCxREF + polarity, OCxN =<br>OCxREF xor CxNP,<br>OCxN_EN = 1                     |
|   |                       | 1 | 1 | 0 | OCxREF + polarity, OCx =<br>OCxREF xor CxP, OCx_EN = 1                                   | Off-state (output enabled<br>with inactive state)<br>OCxN = CxNP, OCxN_EN =<br>1 |
|   |                       | 1 | 1 | 1 | OCxREF + polarity + dead-<br>time, OCx_EN = 1                                            | OCxREF inverted + polarity<br>+ dead-time, OCxN_EN = 1                           |
|   | 0                     |   | 0 | 0 | Output disabled (not driven by                                                           | the timer) Asynchronously:                                                       |
|   | 0                     |   | 0 | 1 | OCx=CxP, OCx_EN= 0,CxI                                                                   | N=CxNP, OCxN_EN = 0;                                                             |
|   | 0                     |   | 1 | 0 | If the clock is present: After a dead-time, $OCx = O$                                    | a dead-time, OCx = OC1IS,                                                        |
|   | 0<br>1<br>1<br>1<br>1 |   | 1 | 1 | OCxN = OCxNIS, assuming the<br>correspond to OCx and                                     |                                                                                  |
| 0 |                       | х | 0 | 0 | Off-state (output enabled                                                                | d and in inactive state)                                                         |
|   |                       |   | 0 | 1 | Asynchronously: OCx =CxP, (                                                              | DCx_EN = 1, OCxN = CxNP,                                                         |
|   |                       |   | 1 | 0 | OCxN_EI                                                                                  |                                                                                  |
|   |                       |   | 1 | 1 | If the clock is present: After a<br>OCxN = OCxNIS, assuming tha<br>correspond to OCx and | at OC1IS and OCxNIS do not                                                       |

Note 1: If the two outputs of a channel are not used (CxEN = CxNEN = 0), OC1IS, OCxNIS, CxP, and CxNP must be cleared.

Note 2: The state of the external I/O pins connected to the complementary OCx and OCxN channels depends on the OCx and OCxN channel state and the GPIO and AFIO registers.



### 10.4.4.10 TMR1 and TMR8 Counter (TMRx\_CNT)

Address offset: 0x24

Reset value: 0x0000

| Bit      | Name      | Туре | Description   |
|----------|-----------|------|---------------|
| Bit 15:0 | CNT[15:0] | rw   | Counter value |

### 10.4.4.11 TMR1 and TMR8 Prescaler (TMRx\_DIV)

Address offset: 0x28

Reset value: 0x0000

| Bit      | Name      | Туре | Description                                                                          |
|----------|-----------|------|--------------------------------------------------------------------------------------|
|          |           |      | Prescaler value                                                                      |
|          |           |      | The counter clock frequency CK_CNT is                                                |
| Bit 15:0 | DIV[15:0] | rw   | $f_{CK_DIV}$ (DIV[15:0]+1).<br>DIV contains the value loaded in the active prescaler |
|          |           |      | register at each update event. Update events include the                             |
|          |           |      | counter cleared by the UEVG bit in the TMR_EVEG register,                            |
|          |           |      | or cleared by the slave controller working in reset mode.                            |

### 10.4.4.12 TMR1 and TMR8 Auto-reload Register (TMRx\_AR)

Address offset: 0x2C

| Bit      | Name     | Туре    | Description                                                  |
|----------|----------|---------|--------------------------------------------------------------|
|          |          |         | Auto-reload value                                            |
|          |          |         | AR contains the value to be loaded to the actual auto-reload |
| Bit 15:0 | AR[15:0] | rw      | register. When auto-reload value is null, the counter does   |
|          |          |         | not work.                                                    |
|          |          |         | Please refer to Section 10.4.3.1 for more details on AR      |
| l ango   |          | Hangzho | u Vango Technologies, Inc. 423 / 782                         |

## 10.4.4.13 TMR1 and TMR8 Repetition Counter Register (TMRx\_RC)

Address offset: 0x30

Reset value: 0x0000

| Bit      | Name    | Туре | Description                                                              |
|----------|---------|------|--------------------------------------------------------------------------|
| Bit 15:8 | -       | -    | Reserved. Always read as 0.                                              |
| Bit 7:0  | RC[7:0] | rw   | Repetition counter value                                                 |
|          |         |      | These bits allow users to set the update rate of the                     |
|          |         |      | compare registers (i.e. periodic transfers from preload                  |
|          |         |      | registers to active registers) after preload registers are               |
|          |         |      | enabled. The update interrupt generation rate is also                    |
|          |         |      | affected, if the update interrupt generation is enabled.                 |
|          |         |      | Each time the down counter RC_CNT reaches zero, an                       |
|          |         |      | update event is generated, and it restarts counting from RC              |
|          |         |      | value. As RC_CNT is reloaded with RC value only at the                   |
|          |         |      | repetition update event U_RC, any write to the TMRx_RC                   |
|          |         |      | register is not taken into account until the next repetition             |
|          |         |      | update event.                                                            |
|          |         |      | It means in PWM mode, (RC+1) corresponds to:                             |
|          |         |      | <ul> <li>The number of PWM periods in edge-aligned mode</li> </ul>       |
|          |         |      | <ul> <li>The number of half PWM period in center-aligned mode</li> </ul> |

### 10.4.4.14 TMR1 and TMR8 Capture/Compare Register 1

### (TMRx\_CC1)

Name

Address offset: 0x34

Reset value: 0x0000

| Bit |  |
|-----|--|
|     |  |

Туре

Description



|          |              |    | Capture/Compare channel 1 value                               |
|----------|--------------|----|---------------------------------------------------------------|
|          |              |    | If CC1 channel is configured as output:                       |
|          |              |    | CC1 is the value to be loaded in the actual capture/compare   |
|          |              |    | 1 register (preload value). The written value is loaded       |
|          |              |    | immediately to the active register if the preload featu re is |
|          | CC1[15:0] rw | rw | not selected in the TMRx_CCM1 register (the OC1PEN bit).      |
|          |              |    | Else, the preload value is loaded in the active               |
| Bit 15:0 |              |    | capture/compare 1 register when an update event occurs.       |
|          |              |    | The active capture/compare register involves in the           |
|          |              |    | comparison with the counter TMRx_CNT, and generates the       |
|          |              |    | output on OC1.                                                |
|          |              |    | If CC1 channel is configured as input:                        |
|          |              |    | CC1 is the counter value transferred by the last input        |
|          |              |    | capture 1 event (IC1).                                        |

# 10.4.4.15 TMR1 and TMR8 Capture/Compare Register 2 (TMRx\_CC2)

Address offset: 0x38

| Bit                                       | Name      | Туре | Description                                                  |
|-------------------------------------------|-----------|------|--------------------------------------------------------------|
|                                           |           |      | Capture/Compare channel 2 value                              |
|                                           |           |      | If CC2 channel is configured as output:                      |
|                                           |           |      | CC2 is the value to be loaded in the actual capture/compare  |
|                                           |           |      | 2 register (preload value). The written value is loaded      |
| Bit 15:0                                  | CC2[15:0] | rw   | immediately to the active register if the preload feature is |
|                                           |           |      | not selected in the TMRx_CCM2 register (the OC2PEN bit).     |
|                                           |           |      | Else, the preload value is loaded in the active              |
|                                           |           |      | capture/compare 2 register when an update event occurs.      |
|                                           |           |      | The active capture/compare register involves in the          |
|                                           |           |      | comparison with the counter, TMRx_CNT, and generates         |
| Hangzhou Vango Technologies, Inc. 425 / 7 |           |      | u Vango Technologies, Inc. 425 / 782                         |

|  | output on OC2.                                         |
|--|--------------------------------------------------------|
|  | If CC2 channel is configured as input:                 |
|  | CC2 is the counter value transferred by the last input |
|  | capture 2 event (IC2).                                 |

## 10.4.4.16 TMR1 and TMR8 Capture/Compare Register 3 (TMRx\_CC3)

Address offset: 0x3C

Reset value: 0x0000

| Bit      | Name              | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------|-------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | Name<br>CC3[15:0] | rw   | Description<br>Capture/Compare channel 3 value<br>If CC3 channel is configured as output:<br>CC3 is the value to be loaded in the actual capture/compare<br>3 register (preload value). The written value is loaded<br>immediately to the active register if the preload feature is<br>not selected in the TMRx_CCM3 register (the OC3PEN bit).<br>Else, the preload value is loaded in the active<br>capture/compare 3 register when an update event occurs.<br>The active capture/compare register involves in the<br>comparison with the counter, TMRx_CNT, and generates<br>output on OC3.<br>If CC3 channel is configured as input:<br>CC3 is the counter value transferred by the last input<br>capture 3 event (IC3). |

### 10.4.4.17 TMR1 and TMR8 Capture/Compare Register 4

### (TMRx\_CC4)

Address offset: 0x40



| Bit      | Name      | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|-----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | CC4[15:0] | rw   | Capture/Compare channel 4 value<br>If CC4 channel is configured as output:<br>CC4 is the value to be loaded in the actual capture/compare<br>4 register (preload value). The written value is loaded<br>immediately to the active register if the preload feature is<br>not selected in the TMRx_CCM4 register (the OC4PEN bit).<br>Else, the preload value is loaded in the active<br>capture/compare 4 register when an update event occurs.<br>The active capture/compare register involves in the<br>comparison with the counter, TMRx_CNT, and generates<br>output on OC4.<br>If CC4 channel is configured as input:<br>CC4 is the counter value transferred by the last input<br>capture 4 event (IC4). |

## 10.4.4.18 TMR1 and TMR8 Break and Dead-time Register (TMRx\_BRKDT)

Address offset: 0x44

Reset value: 0x0000

Note: The AOEN, BRKP, BRKEN, OSIMI, OSIMR, and DTGS[7:0] bits can be write-locked according to LOCK configuration. It is necessary to configure all of them during the first write access to the TMRx\_BRKDT register.

| Bit    | Name | Туре | Description                                                                                                                                                                                                                                                                                                             |
|--------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15 | MOEN | rw   | Main output enable<br>This bit is cleared asynchronously by hardware once the<br>break input is active. It is cleared by software or set<br>automatically depending on the AOEN bit configuration. It<br>acts only on the channels configured as output.<br>0: OC and OCN outputs are disabled or forced to idle state. |



| 1: OC and OCN outputs are enabled if their corresponding<br>enable bits are set (the CxEN, CxNEN bits in the TMRx_C<br>register).         Please refer to Section 10.4.4.9 for more details on OC/C<br>enable.         Automatic output enable         0: MOEN can be set only by software. | -   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| register).<br>Please refer to <u>Section 10.4.4.9</u> for more details on OC/C<br>enable.<br>Automatic output enable                                                                                                                                                                        | CE  |
| Please refer to Section 10.4.4.9 for more details on OC/C       enable.       Automatic output enable                                                                                                                                                                                       |     |
| enable.       Automatic output enable                                                                                                                                                                                                                                                       |     |
| Automatic output enable                                                                                                                                                                                                                                                                     | CN  |
|                                                                                                                                                                                                                                                                                             |     |
| 0: MOEN can be set only by software.                                                                                                                                                                                                                                                        |     |
|                                                                                                                                                                                                                                                                                             |     |
| 1: MOEN can be set by software or set automatically at the                                                                                                                                                                                                                                  | :he |
| Bit 14     AOEN     rw       next update event (if the break input is not active).                                                                                                                                                                                                          |     |
| Note: This bit cannot be modified once LOCK level is set                                                                                                                                                                                                                                    | as  |
| `1' (the LOCKC bits in the TMRx_BRKDT register).                                                                                                                                                                                                                                            |     |
| Break polarity                                                                                                                                                                                                                                                                              |     |
| 0: Break input is active low. 1: Break input is active high                                                                                                                                                                                                                                 | ۱.  |
| Note 1: This bit cannot be modified once LOCK level is se                                                                                                                                                                                                                                   | et  |
| Bit 13     BRKP     rw       as `1' (the LOCKC bits in the TMRx_BRKDT register).                                                                                                                                                                                                            |     |
| Note 2: Any write operation to this bit takes a delay of 1                                                                                                                                                                                                                                  |     |
| APB clock cycle to become effective.                                                                                                                                                                                                                                                        |     |
| Break enable                                                                                                                                                                                                                                                                                |     |
| 0: Break inputs (BRK and CFD clock failure event) is                                                                                                                                                                                                                                        |     |
| disabled.                                                                                                                                                                                                                                                                                   |     |
| 1: Break inputs (BRK and CFD clock failure event) is                                                                                                                                                                                                                                        |     |
| Bit 12 BRKEN rw enabled.                                                                                                                                                                                                                                                                    |     |
| Note 1: This bit cannot be modified once LOCK level is se                                                                                                                                                                                                                                   | ⊃†  |
| as '1' (the LOCKC bits in the TMRx_BRKDT register).                                                                                                                                                                                                                                         |     |
| Note 2: Any write operation to this bit takes a delay of 1                                                                                                                                                                                                                                  |     |
| APB clock cycle to become effective.                                                                                                                                                                                                                                                        |     |
|                                                                                                                                                                                                                                                                                             |     |
| Off-state selection for Run mode                                                                                                                                                                                                                                                            |     |
| This bit is used when MOEN = 1 on channels having a                                                                                                                                                                                                                                         |     |
| Bit 11         OSIMR         rw         complementary output. The OSIMR is not present in the                                                                                                                                                                                               |     |
|                                                                                                                                                                                                                                                                                             |     |
| timer without complementary output.                                                                                                                                                                                                                                                         |     |



|         |            |    | I                                                            |
|---------|------------|----|--------------------------------------------------------------|
|         |            |    | ( <u>Section 10.4.4.9</u> ).                                 |
|         |            |    | 0: When the timer is inactive, OC/OCN outputs are disabled   |
|         |            |    | (OC/OCN enable output signal=0).                             |
|         |            |    | 1: When the timer is inactive, once $CxEN = 1$ or $CxNEN =$  |
|         |            |    | 1, first enable OC/OCN and output the inactive level. Then,  |
|         |            |    | set OC/OCN enable output signal = $1$                        |
|         |            |    | Note: This bit cannot be modified once LOCK level is set as  |
|         |            |    | '2' (the LOCKC bits in the TMRx_BRKDT register).             |
|         |            |    | Off-state selection for Idle mode                            |
|         |            |    | This bit is used when MOEN = 0 on channels configured as     |
|         |            |    | outputs.                                                     |
|         |            |    | Please refer to OC/OCN enable description for more details   |
|         |            |    | (section 10.4.4.9).                                          |
| Bit 10  |            |    | 0: When the timer is inactive, OC/OCN outputs are disabled   |
| Dit 10  | OSIMI      | rw | (OC/OCN enable output signal = 0).                           |
|         |            |    | 1: When the timer is inactive, once $CxEN = 1$ or $CxNEN =$  |
|         |            |    | 1, OC/OCN first outputs the idle levels and OC/OCN enable    |
|         |            |    | output signal = 1.                                           |
|         |            |    | Note: This bit cannot be modified once LOCK level is set as  |
|         |            |    | '2' (the LOCKC bits in the TMRx_BRKDT register).             |
|         |            |    | Lock configuration                                           |
|         |            |    | These bits offer a write protection against software errors. |
|         |            |    | 00: LOCK is OFF, no write protection to the register.        |
|         |            |    | 01: LOCK Level 1, the DTGS, BRKEN, BRKP, AOEN bits in        |
|         |            |    | the TMRx_BRKDT register and the OCXIS/OCxNIS bits in         |
| Bit 9:8 |            |    | the TMRx_CTRL2 register cannot be written.                   |
| DIL 9.0 | LOCKC[1:0] | rw | 10: LOCK Level 2, all bits in LOCK Level 1 and CC polarity   |
|         |            |    | bits (the CxP/CCNxP bits in TMRx_CCE register, if the        |
|         |            |    | related channel is configured as output through the CxSEL    |
|         |            |    | bits) as well as OSIMR/OSIMI bits cannot be written.         |
|         |            |    | 11: LOCK Level 3, all bits in LOCK Level 2 and CC control    |
|         |            |    | bits (the OCxMODE/OCxPEN bits in TMRx_CCMx register if       |
|         |            |    |                                                              |

|         |           | I  |                                                                          |
|---------|-----------|----|--------------------------------------------------------------------------|
|         |           |    | the related channel is configured as output through the                  |
|         |           |    | CxSEL bits) cannot be written.                                           |
|         |           |    | Note: The LOCKC bits can be written only once after the                  |
|         |           |    | reset. Once the TMRx_BRKDT register is written, its content              |
|         |           |    | is frozen until the next reset.                                          |
|         |           |    | Dead-time generator setup                                                |
|         |           |    | The bits define the duration of the dead-time inserted                   |
|         |           |    | between the complementary outputs. Assume that DT                        |
|         |           | rw | represents this duration:                                                |
|         | DTGS[7:0] |    | $DTGS[7:5] = 0xx = > DT = DTGS[7:0] \times Tdtg, Tdtg = TDTS.$           |
|         |           |    | DTGS[7:5] = 10x = > DT = (64+DTGS[5:0]) × Tdtg, Tdtg                     |
|         |           |    | $= 2 \times TDTS.$                                                       |
|         |           |    | DTGS[7:5] = 110 = > DT = (32+DTGS[4:0]) × Tdtg, Tdtg                     |
| Bit 7:0 |           |    | $= 8 \times TDTS.$                                                       |
|         |           |    | DTGS[7:5] = 111 = > DT = (32+DTGS[4:0]) × Tdtg, Tdtg                     |
|         |           |    | = $16 \times TDTS$ .                                                     |
|         |           |    | Example: If TDTS = $125 \text{ ns} (8 \text{ MHz})$ , possible dead-time |
|         |           |    | values are: 0 $\sim$ 15875 ns by the steps of 125 ns, 16 us $\sim$       |
|         |           |    | 31750 ns by the steps of 250 ns, 32 us $\sim$ 63 us by the               |
|         |           |    | steps of 1 u, 64 us $\sim$ 126 us by the steps of 2 us                   |
|         |           |    | Note: The bits cannot be modified once LOCK (the LOCKC                   |
|         |           |    | bits in the TMRx_BRKDT register) level is set as $1'$ , $2'$ , or        |
|         |           |    | `3′.                                                                     |
|         | 1         | 1  | 1                                                                        |

### 10.4.4.19 TMR1 and TMR8 DMA Control Register

### (TMRx\_DMAC)

Address offset: 0x48

| Bit       | Name | Туре | Description                 |
|-----------|------|------|-----------------------------|
| Bit 15:13 | -    | -    | Reserved. Always read as 0. |



|          |             |    | DMA burst length                                                       |
|----------|-------------|----|------------------------------------------------------------------------|
|          |             |    | The bits define the number of DMA transfers in burst mode              |
|          |             |    | (the timer recognizes a burst transfer when a read or a                |
|          |             |    | write access is done to the TMRx_DMABA register). Namely,              |
|          |             |    | defining the number of transfer, and the transfer can be               |
|          |             |    | half-word (two-byte) or byte:                                          |
|          |             |    | 00000: 1 transfer                                                      |
|          |             |    | 00001: 2 transfers                                                     |
|          |             |    | 00010: 3 transfers                                                     |
|          |             |    |                                                                        |
|          |             |    | 10001: 18 transfers                                                    |
|          |             |    | Example: The following transfer is intended: DBLEN = 7,                |
|          |             |    | ADDR = TMR2_CTRL1                                                      |
|          |             |    | - If DBLEN = 7, ADDR = TMR2_CTRL1 represents the address               |
| Bit 12:8 |             |    | to be transferred, the transfer address is obtained from the           |
| Dit 12.0 | DBLEN[4:0]: |    | following formula: (TMRx_CTRL1 address) + ADDR + (DMA                  |
|          |             |    | index), where DMA index = DBLEN.                                       |
|          |             |    | When (TMRx_CTRL1 address) + ADDR + 7, the address to                   |
|          |             |    | be written or read out data will be obtained, and data                 |
|          |             |    | transfer will occur at slave address (TMRx_CTRL1 address)              |
|          |             |    | + 7 registers starting from ADDR.                                      |
|          |             |    | According to the configuration of DMA data length, the                 |
|          |             |    | following conditions may occur:                                        |
|          |             |    | - If data configuration is half-word (16-bit), it will be              |
|          |             |    | transferred to all 7 registers.                                        |
|          |             |    | - If data configuration is byte, it will still be transferred to all 7 |
|          |             |    | registers: The first register contains the first MSB byte, the         |
|          |             |    | second register contains the first LSB byte, and so on.                |
|          |             |    | Therefore, users must define DMA transfer data width for the           |
|          |             |    | timer.                                                                 |
| Bit 7:5  | -           | -  | Reserved. Always read as 0.                                            |
| Bit 4:0  | ADDR[4:0]   | rw | DMA base address                                                       |



Hangzhou Vango Technologies, Inc.

|  | The bits define the base address for DMA transfers in burst |
|--|-------------------------------------------------------------|
|  | mode (when read/write access is done to the TMRx_DMAR       |
|  | register). ADDR is defined as an offset starting from the   |
|  | address of the TMRx_CTRL1 register.                         |
|  | 00000: TMRx_CTRL1                                           |
|  | 00001: TMRx_CTRL2                                           |
|  | 00010: TMRx_SMC                                             |
|  |                                                             |

## 10.4.4.20 TMR1 and TMR8 DMA Address in Burst Mode (TMRx\_DMABA)

Address offset: 0x4C

| Bit      | Name        | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | DMABA[15:0] | rw   | DMA register for burst accesses<br>A read or write to the TMRx_DMAC register accesses the<br>register located at the following address:<br>TMRx_CTRL1 address + ADDR + DMA index, where:<br>TMRx_CTRL1 address is the address of the control register<br>1(TMRx_CTRL1). "ADDR" is the base address defined in the<br>TMRx_DMAC register.<br>"DMA index" is the offset automatically controlled by the<br>DMA, and is determined by the DBLEN bit configured in the<br>TMRx_DMAC register. |



# 11 Watchdog

# 11.1 Window Watchdog (WWDG)

### **11.1.1 WWDG Introduction**

The window watchdog is normally used to detect software malfunctions generated by external interference or by unforeseen logical conditions, which cause the program to abandon its normal sequence. Unless the values of the downcounter are refreshed before the CNTR6 bit becomes '0', the watchdog circuit generates an MCU reset when reaching the programmed time period. An MCU reset is also generated if the 7-bit downcounter value (in the control register) is refreshed before the downcounter reaches the window register value. This means that the downcounter must be refreshed in a limited window.

### 11.1.2 WWDG Main Features

- Programmable free-running downcounter
- Reset under the following conditions:
  - When the downcounter value is less than 0x40 (If the watchdog is enabled.)
  - When the downcounter is reloaded outside the window (if the watchdog is enabled.)

• If the watchdog is activated and the interrupt is enabled, early wakeup interrupt (EWIEN) will be generated when the downcounter reaches 0x40. It can be used to reload the counter to avoid WWDG reset.

### **11.1.3 WWDG Function Overview**

If the watchdog is enabled (the EN bit in the WWDG\_CTRL register is set), and when the 7-bit (CNTR[6:0]) downcounter rolls over from 0x40 to 0x3F (the CNTR6 bit is cleared), a reset is generated. If the counter is reloaded by the software when the value of the counter is greater than the value in the window register, a reset is generated.

Figure 11-1 Watchdog Block Diagram





The program must write in the WWDG\_CTRL register regularly during normal operation to prevent an MCU reset. The write operation can be done only when the counter value is less than the window register value. The value stored in the WWDG\_CTRL register must fall between 0xFF and 0xC0:

• Enable the watchdog.

After system reset, the watchdog is always disabled. Setting the EN bit in the WWDG\_CTRL register can enable the watchdog. Afterwards, it cannot be disabled unless a reset occurs.

• Control the downcounter.

The downcounter is free-running, counting down even if the watchdog is disabled. When the watchdog is enabled, the CNTR6 bit must be set to prevent an immediate reset. The CNTR[5:0] bits contain the number of counting before the watchdog generates a reset. The delay time varies between the minimum and the maximum value due to the unknown status of the prescaler value when writing to the WWDG\_CTRL register. The configuration register (WWDG\_CFG) contains the maximum value of the window: To prevent a reset, the downcounter must be reloaded when its value is less than the window register value and greater than 0x3F. Figure 11-2 shows the window register operation. Another way to reload the counter is to use early wakeup interrupt (EWIEN). Set the WEI bit in the WWDG\_CFG register to enable the interrupt. When the downcounter reaches 0x40, the interrupt is generated. The corresponding interrupt service program (ISTS) can be used to load the counter to prevent WW DG reset. The interrupt can be cleared by writing '0' in the



#### WWDG\_STS register.

*Note: The CNTR6 bit can be used to generate a software reset (Set the EN bit and clear the CNTR6 bit).* 

### **11.1.4 How to Program Watchdog Timeout**

Figure 11-2 provides the formula to calculate the window watchdog timeout.

Warning: When writing to the WWDG\_CTRL register, always set the CNTR6 bit as '1' to avoid an immediate reset.

Figure 11-2 Window Watchdog Timing Diagram





### 11.1.5 Debug Mode

When the microcontroller enters debug mode (Cortex<sup>®</sup>-M4F core halted), the WWDG counter may keep working or stop working, based on the status of the DBG\_WWDG\_STOP configuration bit in the debug module. Please refer to Section 20.2.2 for more details.



## **11.1.6 Register Description**

### 11.1.6.1 Control Register (WWDG\_CTRL)

Address offset: 0x00

Reset value: 0x7F

| Bit      | Name      | Туре | Description                                                       |
|----------|-----------|------|-------------------------------------------------------------------|
| Bit 31:8 | -         | -    | Reserved.                                                         |
|          |           |      | Activation bit                                                    |
| Bit 7    | EN        | FC   | This bit is set by software, but can only be cleared by hardware  |
|          | Bit 7 EN  | rs   | after a reset. When $EN = 1$ , the watchdog can generate a reset. |
|          |           |      | 0: The watchdog is disabled. 1: The watchdog is enabled.          |
|          |           |      | 7-bit counter (MSB to LSB)                                        |
|          |           |      | These bits are used for storing the counter values of the         |
| Bit 6:0  | CNTR[6:0] | rw   | watchdog. Every (4096x2 $^{PSC}$ ) PCLK1 cycle minus 1. When the  |
|          |           |      | counter value changes from 40h to 3Fh (CNTR6 becomes '0'), a      |
|          |           |      | watchdog reset is generated.                                      |

## 11.1.6.2 Configuration Register (WWDG\_CFG)

Address offset: 0x04

| Bit      | Name     | Туре | Description                                                                                                                                                                       |
|----------|----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:8 | -        | -    | Reserved.                                                                                                                                                                         |
| Bit 9    | EWIEN    | rs   | Early wakeup interrupt<br>If this bit is set, an interrupt will be generated when the counter<br>value reaches 40h. The interrupt can only be cleared by<br>hardware after reset. |
| Bit 8:7  | PSC[1:0] | rw   | Timer base<br>The time base of the prescaler can be configured as follows:<br>00: CK Counter Clock (PCLK1 is divided by 4096) is divided by 1.                                    |



|         |            |    | 01: CK Counter Clock (PCLK1 is divided by 4096) is divided by 2. |
|---------|------------|----|------------------------------------------------------------------|
|         |            |    | 10: CK Counter Clock (PCLK1 is divided by 4096) is divided by 4. |
|         |            |    | 11: CK Counter Clock (PCLK1 is divided by 4096) is divided by 8. |
|         |            |    | 7-bit window value                                               |
| Bit 6:0 | WCNTR[6:0] | rw | These bits contain the window values used to compare with the    |
|         |            |    | downcounter.                                                     |

### 11.1.6.3 Status Register (WWDG\_STS)

Address offset: 0x08

Reset value: 0x00

| Bit      | Name | Туре | Description                                                                                                                                                                                                                   |
|----------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:1 | -    | -    | Reserved.                                                                                                                                                                                                                     |
| Bit 0    | EWIF | rs   | Early wakeup interrupt flag<br>This bit is set by hardware when the counter value reaches 40h.<br>It must be cleared by software. Writing '1' to this bit has no<br>effect. This bit is also set if interrupt is not enabled. |

# 11.2 Independent Watchdog (IWDG)

### 11.2.1 Introduction

V84XXX devices have two embedded watchdogs which provide a higher safety level, timing accuracy, and flexibilities. Both watchdog peripherals (independent watchdog and window watchdog) can detect and resolve malfunctions caused by software failures. When the counterreaches a given timeout value, they can trigger an interrupt (window watchdog only) or system reset.

The independent watchdog (IWDG) is clocked by its own dedicated low-speed clock (LSI) and thus stays active even if the main clock fails. The window watchdog (WWDG) is driven by a clock which is prescaled from the APB1 clock. It can detect abnormally late or early application behaviors through a configurable time-window.

IWDG best suits the occasions which require the watchdog to run completely independent of the main application, and have lower timing accuracy requirements. WWDG best suits the applications which



require the watchdog to react within an accurate timing window.

For further information on the window watchdog, please refer to Section 11.1.

### 11.2.2 IWDG Main Features

- Free-running downcounter
- Clocked by an independent RC oscillator (Can work in Stop mode and Standby mode)
- Reset generated when the counter counts to  $0 \times 000$ , after the watchdog is activated.

#### **11.2.3 IWDG Function Overview**

Figure 11-3 is the block diagram showing the functions of the independent watchdog module. The independent watchdog is enabled by writing 0xCCCC into the key register (IWDG\_KEY). At this time, the counter starts downcounting from the reset value, 0xFFF. When the counter counts to the end, 0x000, a reset signal (IWDG\_RESET) is generated.

Anytime when the key register, IWDG\_KEY, is written with 0xAAAA, the value in IWDG\_RLD will be reloaded to the counter to avoid a watchdog reset.

#### 11.2.3.1 Hardware Watchdog

If users enable the "hardware watchdog" function through option bytes, the watchdog will be automatically enabled after system power-on reset. If the corresponding value is not written to the key register by software before the counting ends, a system reset will be generated.

#### 11.2.3.2 Register Access Protection

The IWDG\_PR and IWDG\_RLD registers are write-protected. To modify the values in the two registers, users must write 0x5555 to the IWDG\_KEY register. If a different value is written to this register, the sequence will be interrupted, and the register will be re-protected. Reload operation (write 0xAAAA) also enables the write-protection.

The status register indicates the prescaler value and whether the downcounter is being updated.

#### 11.2.3.3 Debug Mode

When the microcontroller enters debug mode (Cortex<sup>®</sup>-M4F core halted), the IWDG counter will keep



working or stop according to the status of the DBG\_IWDG\_STOP configuration bit in the debug module.

Please refer to the sections about debug module for more details.

Figure 11-3 Block Diagram of Independent W atchdog



Note: The watchdog is implemented in VDD power domain, which means that it can work normally in Stop mode and Standby mode.

| Prescaler Divider | PR[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                                |

Table 11-1 Watchdog Timeout Period (40 k Hz Input Clock (LSI)) (Note)

Note: These timings are given based on the 40 kHz clock. In fact, the frequency of the MCU internal RC still varies between 30 kHz and 60 kHz. In addition, even the frequency of the RC oscillator is accurate, the actual timing still depends on the phase difference between the APB interface clock and the RC oscillator clock. Therefore, there is always an uncertain complete RC cycle.

A relatively accurate watchdog timeout period can be obtained through the calibration to LSI. Please refer to <u>Section 3.2.5</u> for more details on LSI calibration.



# **11.2.4 IWDG Register Description**

# 11.2.4.1 Key Register (IWDG\_KEY)

Address offset: 0x00

Reset value: 0x0000 0000 (Reset by Standby mode)

| Bit       | Name      | Туре | Description                                               |
|-----------|-----------|------|-----------------------------------------------------------|
| Bit 31:16 | -         | -    | Reserved. Always read as 0.                               |
|           | KEY[15:0] |      | Key value (Write-only, the value being read is 0x0000.)   |
|           |           |      | These bits must be written 0xAAAA by software at regular  |
|           |           | rw   | intervals; otherwise, a watchdog reset will be generated  |
|           |           |      | when the counter turns 0. Writing 0x5555 enables accesses |
| Bit 15:0  |           |      | to the IWDG_PR and IWDG_RLD registers. (Please refer to   |
|           |           |      | Section 11.2.3.2)                                         |
|           |           |      | Writing 0xCCCC enables the watchdog (except the           |
|           |           |      | hardware watchdog is selected).                           |

### 11.2.4.2 Prescaler Register (IWDG\_PR)

Address offset: 0x04

Reset value: 0x0000 0000

| Bit      | Name       | Туре | Description                                              |
|----------|------------|------|----------------------------------------------------------|
| Bit 31:3 | -          | -    | Reserved. Always read as 0.                              |
|          | PR[2:0] rw |      | Prescaler divider                                        |
|          |            |      | These bits are write-protected, please refer to Section  |
|          |            | rw   | 11.2.3.2. Users can select the prescaler divider for the |
| Bit 2:0  |            |      | counter clock by setting these bits. To modify the       |
|          |            |      | prescaler divider, the PSCF bit in the IWDG_STS register |
|          |            |      | must be 0.                                               |
|          |            |      | 000: Prescaler divider = 4                               |
|          |            |      | 001: Prescaler divider = 8                               |



| 010: Prescaler divider = 16                                 |
|-------------------------------------------------------------|
| 011: Prescaler divider = 32                                 |
| 100: Prescaler divider = 64                                 |
| 101: Prescaler divider = 128                                |
| 110: Prescaler divider = 256                                |
| 111: Prescaler divider = 256                                |
| Note: Write accesses to this register will return the       |
| prescaler value from VDD power domain. If write             |
| operation is in process, the value being read may be        |
| invalid. Therefore, the value being read is valid only when |
| the PSCF bit in the IWDG_STS register is 0.                 |

### 11.2.4.3 Reload Register (IWDG\_RLD)

Address offset: 0x08

Reset value: 0x0000 0FFF (Reset by Standby mode)

| Bit       | Name           | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|----------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:12 | -              | -    | Reserved. Always read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | -<br>RLD[11:0] | -    | Reserved. Always read as 0.<br>Watchdog counter reload value<br>These bits are write-protected, please refer to <u>Section</u><br><u>11.2.3.2</u> . They are used to define the reload value of the<br>watchdog counter. Every time when the IWDG_KEY<br>register is written with 0xAAAA, the reload value will be<br>sent to the counter. Afterwards, the counter starts<br>downcouting from this value. Watchdog timeout period<br>can be calculated through this reload value and the clock<br>prescaler value. Please refer to Table 11-1.<br>This register can be modified only when the RLDF bit in<br>the IWDG_STS register is 0.<br>Note: Read accesses to this register will return the reload<br>value from VDD power domain. If write operation is in<br>process, the value being read may be invalid. Therefore, |



|  | the value being read is valid only when the RLDF bit in the |
|--|-------------------------------------------------------------|
|  | IWDG_STS register is 0.                                     |

### 11.2.4.4 Status Register (IWDG\_STS)

Address offset: 0x0C

Reset value: 0x0000 0000 (Not reset by Standby mode)

| Bit      | Name | Туре | Description                                                                                                                                                                                                                                                                                                                                        |
|----------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:2 | -    | -    | Reserved.                                                                                                                                                                                                                                                                                                                                          |
| Bit 1    | RLDF | r    | Watchdog counter reload value update<br>This bit is set by hardware to indicate that the reload<br>value update is in process. When the reload update is<br>done in VDD domain, this bit is cleared by hardware (five<br>40 kHz RC cycles are needed at most). The reload value                                                                    |
|          |      |      | can be updated only after the RLDF bit is cleared.                                                                                                                                                                                                                                                                                                 |
| Bit 0    | PSCF | r    | Watchdog prescaler value update<br>This bit is set by hardware to indicate that the prescaler<br>value update is in process. When the prescaler value<br>update is done in VDD domain, this bit is cleared by<br>hardware (five 40 kHz RC cycles are needed at most). The<br>prescaler value can be updated only after the PSCF bit is<br>cleared. |

Note: If several reload values or prescaler values are used in the application, preload values can be changed only after the RLDF bit is cleared, and the prescaler values can be changed only after the PSCF bit is cleared. However, after prescaler and/or reload value are updated, code operation can be continued without waiting for the RLDF or PSCF reset. (This write operation is still executed and completed even in low-power mode.)



# 12 Real-time Clock (RTC)

# **12.1 RTC Introduction**

The real-time clock is an independent timer. The RTC module has a set of continuously running counters which can provide a clock-calendar function with relevant software configurations. Modifying the counter values can reset the current time/date of the system.

The RTC module and clock configuration system (the RCC\_BDC register) are in Backup domain, which means that the RTC setting and time still remain the same after system reset or wakeup from Standby mode.

After system reset, accesses to the backup registers and RTC is disabled. This is to avoid possible undesired write accesses to Backup domain (BRKP). To enable accesses to the backup registers and RTC, proceed as follows:

• Set the PWREN and BKPEN bits in the RCC\_APB1EN register to enable power and backup interface clocks.

• Set the DBP bit in the PWR\_CTRL register to enable accesses to the backup register and RTC.

# 12.2 Main Features

- Programmable prescaler ratio: Division factor up to 2^20
- 32-bit programmable counter for long-term measurement

• Two separate clocks: PCLK1 for APB1 interface and RTC clock (The frequency of RTC clock must be at least four times slower than the PCLK1 clock.)

- 3 RTC clock sources to choose from:
  - HSE clock divided by 128
  - LSE oscillator clock
  - LSI oscillator clock (Please refer to Section 3.2.8.)
- 2 independent reset types:
  - APB1 interface is reset by system reset.
  - The RTC core (prescaler, alarm, counter, and divider) is reset only by Backup domain reset.



(Please refer to Section 3.1.3.)

- 3 dedicated maskable interrupts:
- Alarm interrupt to generate a software programmable alarm interrupt
- Second interrupt to generate a programmable periodic interrupt signal (up to 1 second)

Overflow interrupt to indicate that the internal programmable counter overflows and rolls over to zero.

# **12.3 Function Overview**

### 12.3.1 Introduction

RTC consists of two main units (Please refer to Figure 12-1). The first one (APB1 Interface) is used to interface with the APB1 bus. This unit also contains a set of 16-bit registers accessible from the APB1 bus for read or write operation (Please refer to Section 12.4). The APB1 interface is clocked by the APB1 bus clock in order to interface with the APB1 bus.

The other unit (RTC core) consists of a set of programmable counters divided into two main blocks. The first block is the RTC prescaler block, which can be programmed to generate the RTC time base, LN\_CLK, of which length is up to 1 second. RTC prescaler block includes a 20-bit programmable divider (RTC prescaler). If the corresponding enable bits are set in the RTC\_CTRL register, RTC generates an interrupt (second interrupt) every LN\_CLK period. The second block is a 32-bit programmable counter that can be initialized to the current system time. The system time is incremented by the LN\_CLK period and is compared with the programmable time stored in the ALA register. An alarm interrupt is generated during the comparison and match if the corresponding bits are set in the RTC\_CTRL control register.

Figure 12-1 Simplified RTC Block Diagram





### 12.3.2 Reset Process

All system registers are asynchronously reset by system reset or power reset except for the DIV, ALA, CNT, and DIVCNT registers.

The DIV, ALA, CNT, and DIVCNT registers are reset only by Backup domain reset signal. Please refer to <u>Section 3.1.3</u> for more details.

### 12.3.3 Reading RTC Registers

The RTC core is completely independent of the RTC APB1 interface. Software accesses the RTC prescaler value, counter value, and alarm value through the APB1 interface. However, the relevant readable registers are updated only at rising edge of the RTC clock, which is resynchronized by the RTC APB1 clock. This is also true for the RTC flags.

This suggests that, before the first internal update of the registers, the RTC register value read from APB1 may be corrupted (usually read as 0) if the APB1 interface is previously disabled, and the read



operation occurs immediately after the APB1 interface is re-activated. The following conditions may lead to this situation:

- A system reset or a power reset occurs.
- The system just wakes up from Standby mode (Please refer to <u>Section 2.3.2</u>).
- The system just wakes up from Stop mode (Please refer to <u>Section 2.3.2</u>).

In all the above cases, the RTC core keeps running while the APB1 interface is disabled (reset, not clocked, or not powered). Consequently, when reading the RTC registers, if the RTC APB1 interface is disabled previously, the software must first wait for the RSYNF bit (register synchronized flag) in the RTC\_CTRLL register to be set by hardware.

Note: The RTC APB1 interface is not affected by low-power modes such as WFI and WFE.

### 12.3.4 RTC Register Configuration

To write the DIV, CNT, ALA registers, the CMF bit in the RTC\_CTRLL register must be set to make RTC enter configuration mode.

In addition, write accesses to any RTC register must be proceeded after the previous write operation is completed. Users can check the RTF status bit in the RTC\_CTRLL register to see if the RTC register is being updated. A new value can be written to the RTC registers only when the value of the RTF status bit is `1'.

The configuration procedure is as follows:

- 1. Poll the RTF bit and wait until the RTF value becomes `1'.
- 2. Set the CMF bit to enter configuration mode.
- 3. Write to one or more RTC registers.
- 4. Clear the CMF flag bit to exit configuration mode

5. Poll the RTF bit and wait until the RTF value becomes '1' to ensure that the write operation is completed. Write operations are proceeded only when the CMF flag bit is cleared. It takes at least three RTCCLK cycles.



### 12.3.5 RTC Flag Assertion

In each RTC core clock cycle, the RTC second flag (PACEF) is asserted before the RTC counter is updated. The RTC overflow flag (OVF) is asserted in the last RTC clock cycle before the counter reaches 0x0000. The RTC\_Alarm and RTC alarm flag (ALAF) are asserted in the last RTC clock cycle before the counter reaches the alarm register value + 1 (ALA + 1). Write accesses to the RTC alarm must be synchronized with the RTC second flag by using one of the following sequences:

- Use the RTC alarm interrupt and update the RTC alarm and/or the RTC counter in the interrupt routine.
- Wait for the PACEF bit to be set in the RTC control register, and then update the RTC alarm and/or the RTC counter.



Figure 12-2 Example of RTC Second and Alarm Waveform, PR = 0003, ALARM = 00004

Figure 12-3 Example of RTC Overflow Waveform, PR = 0003





# **12.4 RTC Register Description**

# 12.4.1 RTC Control Register High (RTC\_CTRLH)

Address offset: 0x00

Reset value: 0x0000

| Bit      | Name    | Туре | Description                                                                                                   |
|----------|---------|------|---------------------------------------------------------------------------------------------------------------|
| Bit 15:3 | -       | -    | Reserved, forced to be 0 by hardware.                                                                         |
| Bit 2    | OVIEN   | rw   | Overflow interrupt enable<br>0: Overflow interrupt is masked (disabled).<br>1: Overflow interrupt is enabled. |
| Bit 1    | ALAIEN  | rw   | Alarm interrupt enable<br>0: Alarm interrupt is masked (disabled).<br>1: Alarm interrupt is enabled.          |
| Bit 0    | PACEIEN | rw   | Second interrupt enable<br>0: Second interrupt is masked (disabled).<br>1: Second interrupt is enabled.       |

These bits are used to mask interrupt requests.

Note: All interrupts are masked after a system reset, so writing to the RTC register can ensure that there is no pending interrupt request after initialization. Write accesses to the RTC\_CTRLH register are not allowed when the peripheral is processing the previous write access (The flag bit, RTF, = 0).

RTC function is controlled by this control register. Some write accesses to the bits must be completed through a specific configuration process (Please refer to <u>Section 12.3.4</u>).

# 12.4.2 RTC Control Register Low (RTC\_CTRLL)

Address offset: 0x04



| Bit      | Name  | Туре  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:6 | -     | -     | Reserved, forced to be 0 by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 5    | RTF   | r     | RTC operation OFF<br>The RTC block uses this bit to indicate the status of the last<br>access done to its register, showing whether the access is<br>completed. If the bit is '0', no write access to any of the RTC<br>registers is allowed. This bit is read-only.<br>0: The last write access to the RTC register is in process.<br>1: The last write access to the RTC register is completed.                                                                                           |
| Bit 4    | CMF   | rw    | Configuration flag<br>This bit must be set by software to enter configuration mode,<br>and then allows data to be written to the CNT, ALA, or DIVCNT<br>registers. Write accesses are proceeded only when this bit is set<br>and cleared by software again.<br>0: Exit configuration mode (Start to update the RTC register)<br>1: Enter configuration mode                                                                                                                                 |
| Bit 3    | RSYNF | rc_w0 | Registers synchronized flag<br>This bit is set by hardware every time when the CNT register<br>and the DIVCNT register are updated or cleared by software.<br>After APB1 reset or APB1 clock stops, this bit must be cleared<br>by software. Before beginning any read operation, users must<br>wait until this bit is set by hardware, to ensure that CNT, ALA,<br>or DIVCNT are already synchronized.<br>0: Registers are not yet synchronized.<br>1: Registers are already synchronized. |
| Bit 2    | OVF   | rc_w0 | Overflow flag<br>This bit is set by hardware at 32-bit programmable counter<br>overflow. If OVIEN = 1 in the RTC_CTRLH register, the interrupt<br>is generated. This bit can be cleared only by software. Writing<br>'1' to this bit has no effect.<br>0: No overflow                                                                                                                                                                                                                       |



|       |       |               | 1: 32-bit programmable counter overflow occurs.                    |  |  |
|-------|-------|---------------|--------------------------------------------------------------------|--|--|
|       |       |               | 1. 52 bit programmable counter overnow occurs.                     |  |  |
|       |       |               | Alarm flag                                                         |  |  |
|       |       |               | When the 32-bit programmable counter reaches the threshold         |  |  |
|       |       |               | value programmed by the ALA register, this bit is set by           |  |  |
| Bit 1 | ALAF  | <b>ma</b> 140 | hardware. If ALAIEN = 1 in the $RTC_CTRLH$ register, the           |  |  |
|       | ALAF  | rc_w0         | interrupt is generated. This bit can be cleared only by software.  |  |  |
|       |       |               | Writing '1' to this bit has no effect.                             |  |  |
|       |       |               | 0: Alarm is not detected.                                          |  |  |
|       |       |               | 1: Alarm is detected.                                              |  |  |
|       |       |               | Second flag                                                        |  |  |
|       |       |               | When the 32-bit programmable prescaler overflows, this bit is      |  |  |
|       |       |               | set by hardware; at the same time, the RTC counter + 1.            |  |  |
|       |       |               | Therefore, this flag provides a periodic signal (usually 1 second) |  |  |
|       | DACEE | 0             | for the resolution-programmable RTC counter. If PACEIEN = $1$      |  |  |
| Bit 0 | PACEF | rc_w0         | in the RTC_CTRLH register, the interrupt is generated. This bit    |  |  |
|       |       |               | can be cleared only by software. Writing $1'$ to this bit has no   |  |  |
|       |       |               | effect.                                                            |  |  |
|       |       |               | 0: Second flag condition is not met.                               |  |  |
|       |       |               | 1: Second flag condition is met.                                   |  |  |

RTC function is controlled by this control register. The RTC\_CTRL register cannot be written if the last write operation is not completed yet (Please refer to <u>Section 12.3.4</u>) for more details.

Note: 1. All flag bits remain pending until the corresponding RTC\_CTRL request bits are reset by software, which means that all the interrupt requests are accepted.

2. All interrupts are disabled at reset; the RTC register can be written if there is no pending interrupt request.

3. When APB1 clock is not running, the OVF, ALAF, PACEF, and RSYNF bits are not updated.

4. The OVF, ALAF, PACEF, and RSYNF bits can only be set by hardware and be cleared by software.

5. If ALAF = 1 and ALAIEN = 1, the RTC global interrupt is enabled. If EXTI line 17 interrupt is enabled in the EXTI controller, RTC global interrupt and RTC alarm interrupt are enabled.

6. If ALAF = 1, the RTC alarm interrupt is enabled if EXTI line 17 interrupt mode is set in the EXTI



Hangzhou Vango Technologies, Inc.

controller. When the EXTI line 17 event mode is set in the EXTI controller, a pulse is generated on this line (no RTC alarm interrupt is generated).

# 12.4.3 RTC Prescaler Load Register (RTC\_DIVH/RTC\_DIVL)

The prescaler load registers can store the counting value of RTC prescaler period. They are protected by the RTF bit in the RTC\_CTRL register. Write accesses are allowed only when the RTF bit is '1'.

# 12.4.3.1 RTC prescaler load register high (RTC\_DIVH)

Address offset: 0x08

Write-only (Please refer to Section 12.3.4.)

Reset value: 0x0000

| Bit      | Name       | Туре | Description                                                      |
|----------|------------|------|------------------------------------------------------------------|
| Bit 15:4 | -          | -    | Reserved                                                         |
|          |            |      | RTC prescaler reload value high                                  |
|          |            |      | These bits are used to define the frequency of the counter clock |
|          |            |      | based on the following formula:                                  |
| Bit 3:0  | DIV[19:16] | W    |                                                                  |
|          |            |      | Note: Using 0 is not recommended, or the correct RTC interrupt   |
|          |            |      | and flag cannot be generated.                                    |

# 12.4.3.2 RTC prescaler load register low (RTC\_DIVL)

Address offset: 0x0C

Write-only (Please refer to <u>Section 12.3.4</u>.)

| Bit        | Name               | Туре | Description                                                            |
|------------|--------------------|------|------------------------------------------------------------------------|
| Bit 15:0   |                    | w    | RTC prescaler reload value low                                         |
| Dit 13.0   | Bit 15:0 DIV[15:0] |      | These bits are used to define the frequency of the counter clock based |
| Hango Hang |                    | Hang | zhou Vango Technologies, Inc. 452 / 782                                |

|  | on the following formula:                    |
|--|----------------------------------------------|
|  | $f_{LN\_CLK} = f_{RTCCLK} / (DIV[19:0] + 1)$ |

*Note: If the frequency of the input clock (fRTCCLK) is 32.768 kHz, writing 7FFFh to this register obtains a signal of which period is 1 second.* 

# 12.4.4 RTC Prescaler Divider Register (RTC\_DIVCNTH/RTC\_DIVCNTL)

In every LN\_CLK cycle, the counter value in the RTC prescaler is reset as the value of the DIVCNT register. Users can obtain the current value of the prescaler counter by reading the DIVCNT register without stopping the divider counter, thus gaining accurate time measurement. This register is read-only, and its value is reload by hardware after the values in the DIVCNT or CNT register change.

### 12.4.4.1 RTC prescaler divider register high (RTC\_DIVCNTH)

Address offset: 0x10

Reset value: 0x0000

| Bit      | Name          | Туре | Description            |
|----------|---------------|------|------------------------|
| Bit 15:4 | -             | -    | Reserved               |
| Bit 3:0  | DIVCNT[19:16] | r    | RTC clock divider high |

### 12.4.4.2 RTC prescaler divider register low (RTC\_DIVCNTL)

Address offset: 0x14

| Bit      | Name         | Туре | Description           |
|----------|--------------|------|-----------------------|
| Bit 15:0 | DIVCNT[15:0] | r    | RTC clock divider low |



# 12.4.5 RTC Counter Register (RTC\_CNTH/RTC\_CNTL)

The RTC core has a 32-bit programmable counter which can be accessed through two 16-bit registers; the count counts based on the LN\_CLK time reference generated by the prescaler. The CNT registers store the counting value of the counter. They are write-protected by the RTF bit in the RTC\_CTRL register. A write operation is allowed only if the RTF value is '1'. A write operation on the high (RTC\_CNTH) or low (RTC\_CNTL) registers directly loads the corresponding programmable counter and reloads the RTC prescaler. When reading the registers, the current counting value in the counter (system time) is returned.

### 12.4.5.1 RTC counter register high (RTC\_CNTH)

Address offset: 0x18

Reset value: 0x0000

| Bit      | Name       | Туре | Description                                                                                                                                                                                                                           |
|----------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | CNT[31:16] | w    | RTC counter high<br>Reading the RTC_CNTH register returns the high part of the current RTC<br>counter value. Before writing to this register, it is necessary to enter<br>configuration mode (Please refer to <u>Section 12.3.4</u> ) |

### 12.4.5.2 RTC counter register low (RTC\_CNTL)

Address offset: 0x1C

| Bit      | Name | Туре                                                 | Description                                                              |  |
|----------|------|------------------------------------------------------|--------------------------------------------------------------------------|--|
|          |      |                                                      | RTC counter low                                                          |  |
| Bit 15:0 |      | w                                                    | Reading the RTC_CNTL register returns the low part of the current RTC    |  |
|          |      |                                                      | counter value. Before writing to this register, it is necessary to enter |  |
|          |      | configuration mode (Please refer to Section 12.3.4). |                                                                          |  |



## 12.4.6 RTC Alarm Register (RTC\_ALAH/RTC\_ALAL)

When the value of the programmable counter is equal to the 32-bit value in ALA, an alarm event is triggered, and RTC alarm interrupt is generated. This register is write-protected by the by the RTF bit in the RTC\_CTRL register. A write operation is allowed only if the RTF value is '1'.

### 12.4.6.1 RTC alarm register high (RTC\_ALAH)

Address offset: 0x20

Write-only (Please refer to Section 12.3.4.)

Reset value: 0xFFFF

| Bit      | Name                | Туре | Description                                                               |
|----------|---------------------|------|---------------------------------------------------------------------------|
|          | Bit 15:0 ALA[31:16] |      | RTC alarm high                                                            |
| Bit 15:0 |                     | w    | This register stores the high part of the alarm time written by software. |
|          |                     | Bef  | Before writing to this register, it is necessary to enter configuration   |
|          |                     |      | mode (Please refer to Section 12.3.4).                                    |

### 12.4.6.2 RTC alarm register low (RTC\_ALAL)

Address offset: 0x24

Write-only (Please refer to Section 12.3.4.)

Reset value: 0xFFFF

| Bit      | Name      | Туре      | Description                                                                               |
|----------|-----------|-----------|-------------------------------------------------------------------------------------------|
| Bit 15:0 |           | 4[15:0] w | RTC alarm low<br>This register stores the low part of the alarm time written by software. |
|          | ALA[15:0] |           | Before writing to this register, it is necessary to enter configuration                   |
|          |           |           | mode (Please refer to <u>Section 12.3.4</u> ).                                            |



# 13 Analog-to-Digital Converter (ADC)

# **13.1 ADC Introduction**

The 12-bit ADC is a successive approximation analog-to-digital converter. It has 16 channels to measure the 16 external and 2 internal signal sources. The analog signal of each channel can be converted by the ADC in single, continuous, scan, or discontinuous mode. ADC output can be stored in the 16-bit data register in a left-aligned or right-aligned way.

The analog watchdog allows the application to detect whether the input voltage exceeds the user-defined high/low thresholds.

The ADC input clock is generated from the PCLK2 clock divided by a prescaler, and it cannot exceed 28 MHz. Please refer to Figure 3-2.

# 13.2 ADC Main Features

- 12-bit resolution
- Interrupt generation at the end of conversion, the end of injected conversion, and analog

watchdog event

- Single and continuous conversion modes
- Automatic scan mode from channel 0 to channel n
- Self-calibration: 154 ADC clock cycles
- Data alignment with built-in data coherency
- Channel by channel programmable sampling interval
- External trigger option for both regular and injected conversion
- Discontinuous mode
- Dual mode (on devices with 2 ADCs or more)
- ADC conversion time
  - 0.5 µs at 28 MHz ADC clock (0.7 µs at 180 MHz system clock)
- ADC supply requirement: 2.6 V ~ 3.6 V
- ADC range:  $V_{REF-} \leq V_{IN} \leq V_{REF+}$
- DMA request generation at regular channel conversion

Note: If V<sub>REF</sub>- pin is availaon the package), it must be tied to V<sub>SSA</sub>.



# **13.3 ADC Function Overview**

Figure 13-1 is the block diagram of an ADC module, and Table 13-1 lists the description of ADC pins.





Table 13-1 ADC Pins



| V <sub>REF+</sub> | Input, analog        | The higher/positive reference voltage for the ADC,                     |
|-------------------|----------------------|------------------------------------------------------------------------|
|                   | reference positive   | $2.6 \text{ V} \leq \text{V}_{\text{REF+}} \leq \text{V}_{\text{DDA}}$ |
| VDDA (Note)       | Input, analog supply | Analog power supply equal to VDD and:                                  |
| V                 |                      | $2.6 V \leq VDDA \leq VDD (3.6 V)$                                     |
| V <sub>REF-</sub> | Input, analog        | The lower/negative reference voltage for the ADC,                      |
|                   | reference negative   | $V_{REF-} = V_{SSA}$                                                   |
| VSSA (Note)       | Input, analog supply | Ground for analog power supply equal to V <sub>SS</sub>                |
| V C V             | ground               |                                                                        |
| ADC_IN[15:0]      | Analog input signal  | 16 analog input channels                                               |

Note:  $V_{DDA}$  and  $V_{SSA}$  have to be connected to  $V_{DD}$  and  $V_{SS}$  respectively.

### 13.3.1 ADC Switch

Setting the ADON bit in the ADC\_CTRL2 register can activate the ADC. When setting the ADON bit for the first time, it will wake up the ADC from power-down mode.

Conversion starts when ADON bit is set for the second time after ADC power-on delay time (tSTAB).

Clearing the ADON bit can stop conversion and put the ADC in power-down mode. In this mode, the ADC hardly consumes power (only a few  $\mu$ A).

# 13.3.2 ADC Clock

The ADCCLK clock provided by the clock controller is synchronous with PCLK2 (APB2 clock). The RCC controller provides a dedicated programmable prescaler for the ADC clock. Please refer to the section of reset and clock control (RCC).

### 13.3.3 Channel Selection

There are 18 multiplexed channels. Conversions can be categorized into two groups: regular and injected. A group conversion consists of a sequence of conversions which are done on any channels in any orders. For instance, conversion can be done in the following order: channel 3, channel 8, channel 2, channel 2, channel 0, channel 2, channel 2, and channel 15.

• **Regular group** is composed of up to 16 conversions. The regular channels and their conversion



sequences must be selected in the ADC\_RSQx registers. The total number of conversions in the regular group must be written in the LEN[3:0] bits in the ADC\_RSQ1 register.

• **Injected group** is composed of up to 4 conversions. The injected channels and their conversion sequences must be selected in the ADC\_JSQ register. The total number of conversions in the injected group must be written in the LEN[1:0] bits in the ADC\_JSQ register.

If the ADC\_RSQx register or the ADC\_JSQ register is modified during a conversion, the current conversion is reset, and a new start pulse will be sent to the ADC to convert the new selected group.

#### **13.3.3.1** Temperature sensor/VREFINT internal channels

The temperature sensor is connected to channel ADC1\_IN16, and the internal reference voltage  $V_{REFINT}$  is connected to ADC1\_IN17. These two internal channels can be selected and converted as injected or regular channels.

### **13.3.4 Single Conversion Mode**

In single conversion mode, the ADC performs only one conversion. This mode is started either by setting the ADON bit in the ADC\_CTRL2 register (for a regular channel only) or by external trigger (for both regular and injected channels), the CON bit is 0 in the meantime.

Once the conversion of the selected channel is completed:

- If a regular channel is converted:
  - The converted data is stored in the 16-bit ADC\_RDOR register.
  - The EC (End of Conversion) flag is set.
  - An interrupt is generated if the ECIEN bit is set.
- If an injected channel is converted:
  - $-\,$  The converted data is stored in the 16 -bit ADC\_JDOR1 register.
  - The JEC (End of Conversion Injected) flag is set.
  - An interrupt is generated if the JECIEN bit is set.

Then, the ADC stops.



### **13.3.5 Continuous Conversion Mode**

In continuous conversion mode, the ADC starts another conversion as soon as it finishes the previous one. This mode is started either by external trigger or by setting the ADON bit in the ADC\_CTRL2 register. The CON bit is 1 in the meantime.

After each conversion:

- If a regular channel is converted:
  - $-\,$  The converted data is stored in the 16-bit ADC\_RDOR register.
  - The EC (End of Conversion) flag is set.
  - An interrupt is generated if the ECIEN bit is set.
- If an injected channel is converted:
  - The converted data is stored in the 16-bit ADC\_JDOR1 register.
  - The JEC (End of Conversion Injected) flag is set.
  - An interrupt is generated if the JECIEN bit is set.

### 13.3.6 Timing Diagram

As shown in Figure 13-2, the ADC needs a stabilization time, tSTAB, before it starts converting accurately. After the start of ADC conversion and 14 clock cycles, the EC flag is set, and the 16-bit ADC data register contains the result of the conversion.

Figure 13-2 Timing Diagram





### 13.3.7 Analog Watchdog

The AWD analog watchdog status bit is set if the analog voltage converted by the ADC is below the low threshold or above the high threshold. These thresholds are programmed in the 12 least significant bits of the ADC\_WHTR and ADC\_WLTR registers. The corresponding interrupt can be enabled by setting the AWDIEN bit in the ADC\_CTRL1 register.

The threshold value is independent of the alignment selected by the DALIGN bit in the ADC\_CTRL2 register. The comparison is done before the alignment (Please refer to <u>Section 13.3.12</u>).

The analog watchdog can be enabled on one or more channels by configuring the ADC\_CTRL1 register as shown in Table 13-2.



Figure 13-3 Analog Watchdog Guarded Area

ango

| Channels to be guarded by analog watchdog            | ADC_CTRL1 Register Control Bits |           |            |  |  |  |  |
|------------------------------------------------------|---------------------------------|-----------|------------|--|--|--|--|
| Channels to be guarded by analog watchdog            | AWDSGE bit                      | AWDEN bit | JAWDEN bit |  |  |  |  |
| None                                                 | Any value                       | 0         | 0          |  |  |  |  |
| All injected channels                                | 0                               | 0         | 1          |  |  |  |  |
| All regular channels                                 | 0                               | 1         | 0          |  |  |  |  |
| All regular and injected channels                    | 0                               | 1         | 1          |  |  |  |  |
| Single <sup>(Note)</sup> injected channel            | 1                               | 0         | 1          |  |  |  |  |
| Single <sup>(Note)</sup> regular channel             | 1                               | 1         | 0          |  |  |  |  |
| Single <sup>(Note)</sup> regular or injected channel | 1                               | 1         | 1          |  |  |  |  |

Table 13-2 Analog Watchdog Channel Selection

Note: Selected by the AWDCS [4:0] bits.

### 13.3.8 Scan Mode

This mode is used to scan a group of analog channels.

Scan mode can be selected by setting the SCN bit in the ADC\_CTRL1 register. Once this bit is set, the ADC scans all the channels selected by the ADC\_RSQX registers (for regular channels) or in the ADC\_JSQ (for injected channels). A single conversion is performed on each channel of each group. After each conversion ends, the next channel of the same group is converted automatically. If the CON bit is set, conversion does not stop at the last channel in the selected group, but continues again from the first channel in the selected group.

If the DMAEN bit is set, and the DMA controller transfers the converted data of regular group channels to SRAM after each update of DOR register. On the other hand, the converted data of injected channel is always stored in the ADC\_JDORx register.

### 13.3.9 Injected Channel Management

### 13.3.9.1 Triggered injection

Triggered injection is enabled by clearing the JAUT bit in the ADC\_CTRL1 register and setting the SCN



#### bit.

1. Start the conversion of a group of regular channels either by external trigger or by setting the ADON bit in the ADC\_ CTRL2 register.

2. If an external injected trigger occurs during the regular group channel conversion, the current conversion is reset, and the injected channel sequence is converted in single scan mode.

3. Then, the regular group channel conversion resumes from the last interruption. If a regular event occurs during an injected conversion, the injected conversion will not be interrupted, and the regular sequence will be performed at the end of the injected sequence. Figure 13-4 shows the timing diagram. *Note: When using triggered injection, the interval between trigger events must be longer than the injection sequence. For instance, if the sequence length is 28 ADC clock cycles (that is, two conversions with a 1.5 clock-period sampling time), the minimum interval between triggers must be 29 ADC clock cycles.* 

#### 13.3.9.2 Auto-injection

If the JAUT bit is set, the injected group channels are automatically converted after the regular group channels. This can be used to convert up to 20 conversion sequences programmed in the ADC\_RSQx and ADC\_JSQ registers.

In this mode, external trigger on injected channels must be disabled.

If the CON bit is also set in addition to the JAUT bit, sequences of regular channels to injected channels are continuously converted.

For ADC clock prescaler ratios ranging from 4 to 8, an interval of 1 ADC clock period is automatically inserted when switching from regular conversion to injected sequence, and vice versa. When the ADC clock prescaler ratio is set to 2, the delay is 2 ADC clock periods.

Note: It is not possible to use both auto-injected and discontinuous modes at the same time.

Figure 13-4 Injected Conversion Latency





*Note:* The maximum latency value can be found in the section of electrical characteristics in the V84XXX data sheets.

### 13.3.10 Discontinuous Mode

#### 13.3.10.1 Regular group

This mode is enabled by setting the RDISEN bit in the ADC\_CTRL1 register. It can be used to convert n  $(n \le 8)$  conversions of a short sequence, and this conversion is a part of the conversion sequence selected by the ADC\_RSQx registers. The value, n, is specified by the DISN[2:0] bits in the ADC\_CTRL1 register.

An external trigger signal starts the next n conversions programmed in the ADC\_RSQx register, until all the conversions in the sequence are done. The total sequence length is defined by the LEN [3:0] bits in the ADC\_RSQ1 register.

Example:

n = 3, channels to be converted = 0, 1, 2, 3, 6, 7, 9, 10

First trigger: The converted sequence are 0, 1, and 2. An EC event is generated. Second trigger: The converted sequence are 3, 6, and 7. An EC event is generated. Third trigger: The converted sequence are 9 and 10. An EC event is generated.

Fourth trigger: The converted sequence are 0, 1, and 2. An EC event is generated.



Note: When a regular group is converted in discontinuous mode, no rollover will occur. When all the sub groups are converted, the next trigger starts the conversion of the first sub-group. In the above example, the fourth trigger reconverts the first sub-group channels 0, 1, and 2.

### 13.3.10.2 Injected group

This mode is enabled by setting the JDISEN bit in the ADC\_CTRL1 register. It can be used to convert the sequence selected in the ADC\_JSQ register, channel by channel, after an external trigger event.

An external trigger signal starts the next channel sequence conversion selected in the ADC\_JSQ register, until all the conversions in the sequence are done. The total sequence length is defined by the JLEN [1:0] bits in the ADC\_JSQ register.

Example:

n = 1, channels to be converted = 1, 2, 3 First trigger: Channel 1 is converted.

Second trigger: Channel 2 is converted.

Third trigger: Channel 3 is converted, and EC and JEC events are generated. Fourth trigger: Channel 1 is converted.

*Note:* 1. When all the injected channels are converted, the next trigger starts the conversion of the first injected channel. In the above example, the fourth trigger reconverts the first injected channel 1.

2. It is not possible to use both auto-injected and discontinuous modes at the same time.

3. Users should avoid setting discontinuous mode for both regular and injected groups at the same time. Discontinuous mode must be enabled only for one group conversion.

### 13.3.11 Calibration

The ADC has a built-in self-calibration mode. Calibration significantly reduces accuracy errors resulted from internal capacitor bank variations. During calibration, an error-correction code (digital value) is calculated for each capacitor, and this code is used to remove the errors generated on each capacitor during the subsequent conversions.

Calibration is enabled by setting the CAL bit in the ADC\_CTRL2 register. Once calibration is done, the CAL bit is reset by hardware, and conversion can be performed normally. It is recommended that users



calibrate the ADC once at power-on. The calibration codes are stored in the ADC\_RDOR as soon as the calibration phase ends.

Note: 1. It is recommended that users perform a calibration after each power-up.

2. Before starting a calibration, the ADC must be at power-on state (ADON bit = 1') for at least two ADC clock cycles.

Figure 13-5 Calibration Timing Diagram



### 13.3.12 Data Alignment

The DALIGN bit in the ADC\_CTRL2 register selects the alignment of data stored after conversion. Data can be left-aligned or right-aligned, as shown in Figure 13-6 and Figure 13-7.

The converted data value of injected group channels is decreased by the offset defined in the ADC\_JOFSx registers, so the result can be a negative value. The SEXT bit is the extended sign value.

For regular group channels, offset does not need to be subtracted, so only twelve bits are significant.

Figure 13-6 Right-alignment of Data

Injected group

| SEX | SEXT | SEXT | SEXT | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |
|-----|------|------|------|-----|-----|----|----|----|----|----|----|----|----|----|----|--|
|-----|------|------|------|-----|-----|----|----|----|----|----|----|----|----|----|----|--|

Regular group

| Г |   |   |   |   |     |     |    |    |    |    |    |    |    |    |    |    |
|---|---|---|---|---|-----|-----|----|----|----|----|----|----|----|----|----|----|
|   | 0 | 0 | 0 | 0 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|   |   |   |   |   |     |     |    |    |    |    |    |    |    |    |    |    |

Figure 13-7 Left-alignment of Data

Injected group



|               |     |     |    | -  |    |    | -  | -  |            |    | -  |    |   |   |   |
|---------------|-----|-----|----|----|----|----|----|----|------------|----|----|----|---|---|---|
|               |     |     |    |    |    |    |    |    |            |    |    |    |   |   |   |
|               |     |     |    | _  |    | _  |    |    | <b>D D</b> | _  |    |    | _ | _ | _ |
| SEXT          | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3         | D2 | D1 | D0 | 0 | 0 | 0 |
| <b>-</b> /··· |     |     |    |    |    |    |    |    |            |    |    |    | • | • | • |
| JJ            |     |     |    |    |    |    |    |    |            |    |    |    |   |   |   |

Regular group

| D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | 0 | 0 | 0 | 0 |
|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|

### **13.3.13** Programmable Channel Sample Time

The ADC samples the input voltage by using several ADC\_CLK cycles. The sampling cycle number can be modified through the SMP[2:0] bits in the ADC\_SMPT1 and ADC\_SMPT2 registers. Each channel can be sampled with a different sample time.

The total conversion time is calculated as follows:

 $T_{CONV}$  = Sampling time + 12.5 cycles For example:

With an ADCCLK = 14 MHz and a sampling time of 1.5 cycles:

TCONV = 1.5 + 12.5 = 14 cycles = 1 µs

# 13.3.14 Conversion on External Trigger

Conversion can be triggered by an external event (e.g. timer capture, EXTI line). If the EXTTRIG control bit is set, then external events can trigger a conversion. The EXSEL[3:0] and JEXSEL[3:0] control bits allow the application to select one event out of the 16 possible events to trigger conversion for the regular and injected groups.

Note: When an external trigger signal is selected for ADC regular or injected conversion, only its rising edge can start the conversion.

| Source          | Туре                                | EXSEL[3:0] |
|-----------------|-------------------------------------|------------|
| TMR1_CC1 event  |                                     | 0000       |
| TMR1_CC2 event  |                                     | 0001       |
| TMR1_CC3 event  | Internal signal from on-chip timers | 0010       |
| TMR2_CC2 event  |                                     | 0011       |
| TMR3_TRGO event |                                     | 0100       |

Table 13-3 ADC1 Used in External Trigger for Regular Channels



| TMR4_CC4 event                     |                                                  | 0101 |
|------------------------------------|--------------------------------------------------|------|
| EXTI line 11/TMR8_TRGO event(Note) | External pin/Internal signal from on-chip timers | 0110 |
| SWSTR                              | Software control bit                             | 0111 |
| TMR1_TRGO event                    |                                                  | 1101 |
| TMR8_CC1 event                     | Internal signal from on-chip timers              | 1110 |
| TMR8_CC2 event                     |                                                  | 1111 |

Note: For regular channels, the selection of the EXTI line 11 or TMR8\_TRGO as external trigger event is done through the configuration of the ADC1\_ETRGREG\_REMAP bit and in ADC1.

Table 13-4 ADC1 Used in External Trigger for Injected Channels

| Source                                        | Туре                                                | JEXSEL[3:0] |
|-----------------------------------------------|-----------------------------------------------------|-------------|
| TMR1_TRGO event                               |                                                     | 0000        |
| TMR1_CC4 event                                |                                                     | 0001        |
| TMR2_TRGO event                               | Internal cignal from on chin timors                 | 0010        |
| TMR2_CC1 event                                | Internal signal from on-chip timers                 | 0011        |
| TMR3_CC4 event                                |                                                     | 0100        |
| TMR4_TRGO event                               |                                                     | 0101        |
| EXTI line 15/TMR8_CC4 event <sup>(Note)</sup> | External pin/Internal signal from on-chip<br>timers | 0110        |
| JSWSTR                                        | Software control bit                                | 0111        |
| TMR1_CC1 event                                |                                                     | 1101        |
| TMR8_CC1 event                                | Internal signal from on-chip timers                 | 1110        |
| TMR8_TRGO event                               |                                                     | 1111        |

Note: For injected channels, the selection of the EXTI line 15 or TMR8\_CC4 as external trigger event is done through the configuration of the ADC1\_ETRGINJ\_REMAP bit in the ADC1

Software trigger events can be generated by setting the SWSTR or JSWSTR bit in the ADC\_CTRL2 register.

A regular group conversion can be interrupted by an injected trigger.



# 13.3.15 DMA Request

Since the converted values of regular channels are stored in the only one data register, it is necessary to use DMA for conversion of more than one regular channel. This avoids the loss of data which is already stored in the ADC\_RDOR register.

A DMA request is generated only at the end of a regular channel conversion, which transfers its converted data from the ADC\_RDOR register to the destination location designated by the user.

# 13.3.16 Temperature Sensor

The temperature sensor can measure the ambient temperature  $(T_A)$  of the device. It is internally connected to the ADC1\_IN16 input channel, which converts the sensor output voltage into a digital value. The recommended sampling time for the temperature sensor analog input is 8.6  $\mu$ s.

The block diagram of the temperature sensor is shown in Figure 13-8. When not in use, this sensor can be put in power-down mode.

Note: The TSREF bit must be set to enable internal channels: ADC1\_IN16 (temperature sensor) and ADC1\_IN17 (VREFINT) conversion.

The output voltage of temperature sensor changes linearly with temperature. The offset of this line varies from chip to chip (up to 45 °C) due to process variation. The internal temperature sensor is more appropriate for detecting temperature variations instead of absolute temperatures. If accurate temperature readings are needed, an external temperature sensor should be used.

Figure 13-8 Channel Block Diagram of Temperature Sensor and VREFINT





Reading the temperature To use the sensor:

1. Select the ADC1\_IN16 input channel.

2. Select a sample time of 8.6  $\mu s.$ 

3. Set the TSREF bit in the ADC control register 2 (ADC\_CTRL2), to wake up the temperature sensor from power-down mode.

4. Start the ADC conversion by setting the ADON bit (or by external trigger).

5. Read the  $V_{\mbox{\scriptsize SENSE}}$  data result in the ADC data register.

6. Obtain the temperature with the following formula: Temperature (°C) =  $\{(V_{25} - V_{SENSE}) / Avg_Slope\}$ 

+ 25 Where:

V<sub>25</sub> = V<sub>SENSE</sub> value for 25 °C

Avg\_Slope = Average slope for curve between temperature and  $V_{SENSE}$  (given in mV/°C or  $\mu$ V/°C)

Please refer to the section of electrical characteristics in the data sheet for the actual values of  $V_{25}$  and  $Avg_Slope$ .

Note: After waking from power-down mode, the sensor has a startup time before it can output VSENSE at the correct level. The ADC also has a startup time after power-on, so to minimize the delay, the ADON and TSREF bits should be set at the same time.

# **13.3.17 ADC Interrupts**

For regular and injected groups, an interrupt can be generated at the end of conversion and when the



analog watchdog status bit is set. Separate interrupt enable bits are available.

Two other flags are present in the ADC\_register, but they do not have related interrupts:

- JSTR (Start of injected group channels conversion)
- RSTR (Start of regular group channels conversion)

#### Table 13-5 ADC Interrupts

| Interrupt Event                   | Flag | Enable Control Bit |
|-----------------------------------|------|--------------------|
| End of regular group conversion   | EC   | ECIEN              |
| End of injected group conversion  | JEC  | JECIEN             |
| The analog watchdog status bit is | AWD  | AWDIEN             |
| set                               |      |                    |

# 13.4 ADC Registers

# 13.4.1 ADC Status Register (ADC\_STS)

Address offset: 0x00

| Bit       | Name | Туре  | Description                                                                                                                                                                                                                                                                                                                                  |
|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:15 | -    | -     | Reserved. Must be kept as 0.                                                                                                                                                                                                                                                                                                                 |
| Bit 4     | RSTR | rc_w0 | Regular channel Start flag<br>This bit is set by hardware at the start of regular channel<br>conversion, and it is cleared by software.<br>0: Regular channel conversion is not started yet.                                                                                                                                                 |
| Bit 3     | JSTR | rc_w0 | <ol> <li>Regular channel conversion is started.</li> <li>Injected channel Start flag</li> <li>This bit is set by hardware at the start of injected channel group conversion, and it is cleared by software.</li> <li>Injected channel group conversion is not started yet.</li> <li>Injected channel group conversion is started.</li> </ol> |



| Bit 2 | JEC | rc_w0 | Injected channel end of conversion<br>This bit is set by hardware at the end of all injected channel<br>group conversion, and it is cleared by software.<br>0: Conversion is not completed yet.<br>1: Conversion is completed.                                      |
|-------|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 1 | EC  | rc_w0 | End of conversion<br>This bit is set by hardware at the end of channel group<br>conversion (regular or injected) channel, and it is cleared by<br>software or by reading ADC_RDOR.<br>0: Conversion is not completed yet.<br>1: Conversion is completed.            |
| Bit 0 | AWD | rc_w0 | Analog watchdog flag<br>This bit is set by hardware when the converted voltage exceeds<br>the values programmed in the ADC_WLTR and ADC_WHTR<br>registers. It is cleared by software.<br>0: No analog watchdog event occurs.<br>1: An analog watchdog event occurs. |

# 13.4.2 ADC Control Register 1 (ADC\_CTRL1)

Address offset: 0x04

| Bit       | Name   | Туре | Description                                                                                                                                                                                                                    |
|-----------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:24 | -      | -    | Reserved. Must be kept as 0.                                                                                                                                                                                                   |
| Bit 23    | AWDEN  | rw   | <ul> <li>Analog watchdog enable on regular channels This bit is set and cleared by software.</li> <li>0: Analog watchdog is disabled on regular channel.</li> <li>1: Analog watchdog is enabled on regular channel.</li> </ul> |
| Bit 22    | JAWDEN | rw   | Analog watchdog enable on injected channels This bit is set and cleared by software.                                                                                                                                           |



|           |              |          | 0: Analog watchdog is disabled on injected channel.              |
|-----------|--------------|----------|------------------------------------------------------------------|
|           |              |          | 1: Analog watchdog is enabled on injected channel.               |
|           |              |          |                                                                  |
| Bit 21:16 | -            | -        | Reserved. Must be kept as 0.                                     |
|           |              |          | Discontinuous mode channel count                                 |
|           |              |          | These bits are written by software to define the number of       |
|           |              |          | regular channels to be converted after receiving an external     |
| Bit 15:13 | DISN[2:0]    | rw       | trigger in discontinuous mode.                                   |
|           |              |          | 000: 1 channel                                                   |
|           |              |          | 001: 2 channels                                                  |
|           |              |          |                                                                  |
|           |              |          | 111: 8 channels                                                  |
|           |              |          | Discontinuous mode on injected channels                          |
|           |              |          | This bit is set and cleared by software to enable or disable     |
| Bit 12    | JDISEN       | rw       | discontinuous mode on injected channels.                         |
|           |              |          | 0: Discontinuous mode is disabled on injected channels.          |
|           |              |          | 1: Discontinuous mode is enabled on injected channels.           |
|           |              |          | Discontinuous mode on regular channels                           |
|           |              | ISEN rw  | This bit is set and cleared by software to enable or disable     |
| Bit 11    | RDISEN       |          | discontinuous mode on regular channels.                          |
|           |              |          | 0: Discontinuous mode is disabled on regular channels.           |
|           |              |          | 1: Discontinuous mode is enabled on regular channels.            |
|           |              |          | Automatic Injected Group conversion                              |
|           |              |          | This bit is set and cleared by software to enable or disable     |
|           |              |          |                                                                  |
| Bit 10    | JAUT         | rw       | automatic injected group conversion after regular channel group  |
|           |              |          | conversion ends.                                                 |
|           |              |          | 0: Automatic injected channel group conversion is disabled. 1:   |
|           |              |          | Automatic injected channel group conversion is enabled.          |
|           |              |          | Enable the watchdog on a single channel in scan mode             |
| Bit 9     | Bit Q AWDSGE | WDSGE rw | This bit is set and cleared by software to enable or disable the |
|           |              |          | analog watchdog function defined by the AWDCS[4:0] bits.         |
|           |              |          | 0: Analog watchdog is enabled on all channels.                   |



|          |            |    | 1: Analog watchdog is enabled on a single channel.                |
|----------|------------|----|-------------------------------------------------------------------|
|          |            |    | Scan mode                                                         |
|          |            |    | This bit is set and cleared by software to enable or disable scan |
|          |            |    | mode. In scan mode, channels selected by the ADC_RSQx or          |
|          |            |    | ADC_JSQx register are converted.                                  |
| Bit 8    | SCN        | rw | 0: Scan mode is disabled.                                         |
|          |            |    | 1: Scan mode is enabled.                                          |
|          |            |    | Note: If the ECIEN or JECIEN bits are set respectively, EC or     |
|          |            |    | JEC interrupt is generated only after the last channel conversion |
|          |            |    | is completed.                                                     |
|          |            |    | Interrupt enable for injected channels                            |
|          |            |    | This bit is set and cleared by software to enable or disable      |
|          |            |    | interrupt generation after all injected channel conversions are   |
| Bit 7    | JECIEN     | rw | completed.                                                        |
|          |            |    | 0: JEC interrupt is disabled.                                     |
|          |            |    | 1: JEC interrupt is enabled. Interrupt is generated when the JEC  |
|          |            |    | bit is set by hardware.                                           |
|          |            |    | Analog watchdog interrupt enable                                  |
|          |            | rw | This bit is set and cleared by software to enable or disable      |
|          |            |    | analog watchdog interrupt. In scan mode, if the watchdog          |
| Bit 6    | AWDIEN     |    | detects values exceeding the threshold, the scan will be stopped  |
|          |            |    | only if this bit is set.                                          |
|          |            |    | 0: Analog watchdog interrupt is disabled.                         |
|          |            |    | 1: Analog watchdog interrupt is enabled.                          |
|          |            |    | Interrupt enable for EC                                           |
|          |            |    | This bit is set and cleared by software to enable or disable      |
| Bit 5 EC |            | rw | interrupt generation after conversion.                            |
|          | ECIEN      |    | 0: EC interrupt is disabled.                                      |
|          |            |    | 1: EC interrupt is enabled. An interrupt is generated when the    |
|          |            |    | EC bit is set by hardware.                                        |
| Bit 4:0  | AWDCS[4:0] | rw | Analog watchdog channel select bits                               |
| L        | 1          |    | 1                                                                 |



|  | These bits are set and cleared by software to select the input               |
|--|------------------------------------------------------------------------------|
|  | channel to be protected by the analog watchdog.                              |
|  | 00000: ADC analog input channel 0                                            |
|  | 00001: ADC analog input channel 1                                            |
|  |                                                                              |
|  | 01111: ADC analog input channel 15                                           |
|  | 10000: ADC analog input channel 16                                           |
|  | 10001: ADC analog input channel 17 All the other values are                  |
|  | reserved.                                                                    |
|  | Note: ADC1 analog channel16 and channel17 are internally                     |
|  | connected to the temperature sensor and to $V_{\mbox{\scriptsize REFINT}}$ , |
|  | respectively.                                                                |

# 13.4.3 ADC Control Register 2 (ADC\_CTRL2)

Address offset: 0x08

| Bit       | Name      | Туре | Description                                                                                                                                                                                                                                                                                             |
|-----------|-----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:24 | -         | -    | Reserved. Must be kept as 0.                                                                                                                                                                                                                                                                            |
| Bit 25    | EXSEL[3]  | rw   | Please refer to EXSEL[3:0] definition.                                                                                                                                                                                                                                                                  |
| Bit 24    | JEXSEL[3] | rw   | Please refer to JEXSEL[3:0] definition.                                                                                                                                                                                                                                                                 |
| Bit 23    | TSREF     | rw   | Temperature sensor and VREFINT enable<br>This bit is set and cleared by software, to enable or disable the<br>temperature sensor and V <sub>REFINT</sub> channel. In devices with more<br>than one ADC, this bit is present only in ADC1.<br>0: Temperature sensor and V <sub>REFIN</sub> are disabled. |
| Bit 22    | SWSTR     | rw   | <ol> <li>Temperature sensor and VREFIN are enabled.</li> <li>Start conversion of regular channels</li> <li>This bit is set by software to start conversion, and it is cleared</li> <li>by hardware as soon as the conversion starts. This bit can start</li> </ol>                                      |



|           |            |      | the conversion of a regular channel group if SWSTR is selected   |
|-----------|------------|------|------------------------------------------------------------------|
|           |            |      | as trigger event in the EXSEL[3:0] bits.                         |
|           |            |      | 0: Reset state                                                   |
|           |            |      | 1: Start regular channel conversion                              |
|           |            |      |                                                                  |
|           |            |      | Start conversion of injected channels                            |
|           |            |      | This bit is set by software to start conversion, and it can be   |
|           |            |      | cleared by software, or by hardware as soon as the conversion    |
| Bit 21    | JSWSTR     | 5147 | starts. This bit can start the conversion of an injected channel |
|           | JSWSIK     | rw   | group if JSWSTR is selected as trigger event in the JEXSEL[3:0]  |
|           |            |      | bits.                                                            |
|           |            |      | 0: Reset state                                                   |
|           |            |      | 1: Start injected channel conversion                             |
|           |            |      | External trigger conversion mode for regular channels            |
|           |            |      | This bit is set and cleared by software to enable or disable     |
|           |            |      | external trigger event which starts regular channel group        |
| Bit 20    | EXTTRIG    | rw   | conversion.                                                      |
|           |            |      | 0: Conversion on external event is disabled.                     |
|           |            |      | 1: Conversion on external event is enabled.                      |
|           |            |      | External event select for regular group                          |
|           |            |      | These bits select the external event that starts regular channel |
|           |            |      | group conversion.                                                |
|           |            |      |                                                                  |
|           |            |      | Trigger configurations for ADC1 are as follows:                  |
|           |            |      | 0000: Timer 1 CC1 event                                          |
| Bit 25    |            |      | 0001: Timer 1 CC2 event                                          |
| Bit 19:17 | EXSEL[3:0] | rw   | 0010: Timer 1 CC3 event                                          |
|           |            |      | 0011: Timer 2 CC2 event                                          |
|           |            |      | 0100: Timer 3 TRGO event                                         |
|           |            |      | 0101: Timer 4 CC4 event                                          |
|           |            |      | 0110: EXTI line 11/ TMR8_TRGO event                              |
|           |            |      | 0111: SWSTR                                                      |
|           |            |      | 1000: Timer 15 CC1 event                                         |



| -         | T           | 1             |                                                                   |
|-----------|-------------|---------------|-------------------------------------------------------------------|
|           |             |               | 1001: Timer 15 CC2 event                                          |
|           |             |               | 1010: Timer 15 CC3 event                                          |
|           |             |               | 1011: Timer 15 CC4 event                                          |
|           |             |               | 1100: Timer 15 TRGO event                                         |
|           |             |               | 1101: Timer 1 TRGO event                                          |
|           |             |               | 1110: Timer 8 CC1 event                                           |
|           |             |               | 1111: Timer 8 CC2 event                                           |
| Bit 16    | -           | -             | Reserved. Must be kept as 0.                                      |
|           |             |               | External trigger conversion mode for injected channels            |
|           |             |               | This bit is set and cleared by software to enable or disable      |
| Bit 15    |             |               | external trigger event which starts injected channel group        |
| DIL 15    | JEXTTRIG    | rw            | conversion.                                                       |
|           |             |               | 0: Conversion on external event is disabled.                      |
|           |             |               | 1: Conversion on external event is enabled.                       |
|           |             |               | External event select for injected group                          |
|           |             |               | These bits select the external event that starts injected channel |
|           |             |               | group conversion.                                                 |
|           |             |               | Trigger configurations for ADC1 are as follows:                   |
|           |             |               | 0000: Timer 1 TRGO event                                          |
|           |             |               | 0001: Timer 1 CC4 event                                           |
|           |             |               | 0010: Timer 2 TRGO event                                          |
|           |             |               | 0011: Timer 2 CC1 event                                           |
| Bit 24    |             | <b>1</b> 7147 | 0100: Timer 3 CC4 event                                           |
| Bit 14:12 | JEXSEL[3:0] | rw            | 0101: Timer 4 TRGO event                                          |
|           |             |               | 0110: EXTI line 15/TMR8_CC4 event                                 |
|           |             |               | 0111: JSWSTR                                                      |
|           |             |               | 1000: Timer 15 CC1 event                                          |
|           |             |               | 1001: Timer 15 CC2 event                                          |
|           |             |               | 1010: Timer 15 CC3 event                                          |
|           |             |               | 1011: Timer 15 CC4 event                                          |
|           |             |               | 1100: Timer 15 TRGO event                                         |
|           |             |               | 1101: Timer 1 CC1 event                                           |
|           |             |               |                                                                   |



|          |        |    | 1110: Timer 8 CC1 event                                            |
|----------|--------|----|--------------------------------------------------------------------|
|          |        |    | 1111: Timer 8 TRGO event                                           |
|          |        |    | Data alignment                                                     |
|          |        |    | This bit is set and cleared by software. Please refer to Figure    |
| Bit 11   | DALIGN | rw | 13-6 and Figure 13-7.                                              |
|          |        |    | 0: Right alignment                                                 |
|          |        |    | 1: Left alignment                                                  |
| Bit 10:9 | -      | -  | Reserved. Must be kept as 0.                                       |
|          |        |    | Direct memory access mode                                          |
|          |        |    | This bit is set and cleared by software. Please refer to the       |
| Bit 8    | DMAEN  | rw | section of DMA Controller.                                         |
|          |        |    | 0: DMA mode is disabled.                                           |
|          |        |    | 1: DMA mode isenabled.                                             |
| Bit 7:4  | -      | -  | Reserved. Must be kept as 0.                                       |
|          |        |    | Reset calibration                                                  |
|          |        |    | This bit is set by software and cleared by hardware. It is cleared |
|          |        |    | after the calibration register is initialized.                     |
| Bit 3    | RSTCAL | rw | 0: Calibration register is initialized.                            |
|          |        |    | 1: Initialize calibration register                                 |
|          |        |    | Note: If RSTCAL is set when conversion is ongoing, additional      |
|          |        |    | cycles are required to clear the calibration registers.            |
|          |        |    | A/D Calibration                                                    |
|          |        |    | This bit is set by software to start calibration and cleared by    |
| Bit 2    | CAL    | rw | hardware when the calibration is completed.                        |
|          |        |    | 0: Calibration is completed.                                       |
|          |        |    | 1: Start calibration                                               |
|          |        |    | Continuous conversion                                              |
|          |        |    | This bit is set and cleared by software. If this bit is set,       |
| Bit 1    | CON    | rw | conversion will be continuously performed until this bit is        |
|          |        |    | cleared.                                                           |
|          |        |    | 0: Single conversion mode                                          |



|       |            |    | 1: Continuous conversion mode                                                          |
|-------|------------|----|----------------------------------------------------------------------------------------|
|       |            |    | A/D converter ON/OFF                                                                   |
|       |            |    | This bit is set and cleared by software. When this bit is $0'$ ,                       |
|       |            |    | writing '1' will wake up the ADC from power-down mode.                                 |
|       |            |    | When this bit is `1', writing `1' will enable conversion. The                          |
|       |            | rw | application should allow a delay of $t_{\mbox{\scriptsize STAB}}$ between power-up and |
| Bit 0 |            |    | start of conversion. Please refer to Figure 13-2.                                      |
| Die O | Bit 0 ADON |    | 0: Disable ADC conversion/calibration and enter power-down                             |
|       |            |    | mode                                                                                   |
|       |            |    | 1: Enable ADC to start conversion                                                      |
|       |            |    | Note: If any other bit in this register is changed with the ADON                       |
|       |            |    | bit at the same time, then conversion is not triggered. This is to                     |
|       |            |    | prevent triggering a wrong conversion.                                                 |

# 13.4.4 ADC Sample Time Register 1 (ADC\_SMPT1)

Address offset: 0x0C

| Bit       | Name      | Туре | Description                                                      |
|-----------|-----------|------|------------------------------------------------------------------|
| Bit 31:24 | -         | -    | Reserved. Must be kept as 0.                                     |
|           |           |      | Channel x Sample time selection                                  |
|           |           |      | These bits select the sample time for each channel individually. |
|           |           |      | During sample cycles, channel selection bits must remain         |
|           |           |      | unchanged.                                                       |
|           |           |      | 000: 1.5 cycles                                                  |
| Bit 23:0  | SMPx[2:0] | rw   | 001: 7.5 cycles                                                  |
|           |           |      | 010: 13.5 cycles                                                 |
|           |           |      | 011: 28.5 cycles                                                 |
|           |           |      | 100: 41.5 cycles                                                 |
|           |           |      | 101: 55.5 cycles                                                 |
|           |           |      | 110: 71.5 cycles                                                 |



|  | 111: 239.5 cycles                                                                       |
|--|-----------------------------------------------------------------------------------------|
|  | Note: ADC1 analog input channel16 and channel 17 are                                    |
|  | internally connected to the temperature sensor and to $V_{\mbox{\scriptsize REFINT}}$ , |
|  | respectively.                                                                           |

# 13.4.5 ADC Sample Time Register 2 (ADC\_SMPT2)

Address offset: 0x10

Reset value: 0x0000 0000

| Bit       | Name           | Туре | Description                                                                                                                                                                                                                                                                                                             |
|-----------|----------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:30 | -              | -    | Reserved. Must be kept as 0.                                                                                                                                                                                                                                                                                            |
| Bit 31:30 | -<br>SMPx[2:0] | rw   | Channel x Sample time selection<br>These bits select the sample time for each channel individually.<br>During sample cycles, channel selection bits must remain<br>unchanged.<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles |
|           |                |      | 111: 239.5 cycles                                                                                                                                                                                                                                                                                                       |

# 13.4.6 ADC Injected Channel Data Offset Register x (ADC\_JOFSx) (x = 1...4)

Address offset:  $0x14 \sim 0x20$ 

| Bit Name Type Description |
|---------------------------|
|---------------------------|



| Bit 31:12 | -             | -          | Reserved. Must be kept as 0.                                                                                     |
|-----------|---------------|------------|------------------------------------------------------------------------------------------------------------------|
| Bit 11:0  |               |            | Data offset for injected channel x                                                                               |
|           | 10ECT./[11.0] | <b>F14</b> | These bits define the offset to be subtracted from the raw converted data when converting injected channels. The |
|           | JOFSTx[11:0]  | rw         |                                                                                                                  |
|           |               |            | conversion result can be read from in the ADC_JDORx registers.                                                   |

# 13.4.7 ADC Watchdog High Threshold Register (ADC\_WHTR)

Address offset: 0x24

Reset value: 0x0000 0000

| Bit       | Name       | Туре | Description                                               |
|-----------|------------|------|-----------------------------------------------------------|
| Bit 31:12 | -          | -    | Reserved. Must be kept as 0.                              |
| Bit 11:0  | Rit 11:0   |      | Analog watchdog high threshold                            |
| Dit 11.0  | AWHT[11:0] | rw   | These bits define the high threshold for analog watchdog. |

# 13.4.8 ADC Watchdog Low Threshold Register (ADC\_WLTR)

Address offset: 0x28

Reset value: 0x0000 0000

| Bit       | Name       | Туре | Description                                              |
|-----------|------------|------|----------------------------------------------------------|
| Bit 31:12 | -          | -    | Reserved. Must be kept as 0.                             |
| Bit 11:0  |            |      | Analog watchdog low threshold                            |
| Dit 11.0  | AWLT[11:0] | rw   | These bits define the low threshold for analog watchdog. |

# 13.4.9 ADC Regular Sequence Register 1 (ADC\_RSQ1)

Address offset: 0x2C



| Bit       | Name      | Туре | Description                                                                                                                                                                                                                         |
|-----------|-----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:24 | -         | -    | Reserved. Must be kept as 0.                                                                                                                                                                                                        |
| Bit 23:20 | LEN[3:0]  | rw   | Regular channel sequence length<br>These bits are set by software to define the total number of<br>conversions in the regular channel conversion sequence.<br>0000: 1 conversion<br>0001: 2 conversions<br><br>1111: 16 conversions |
| Bit 19:15 | SQ16[4:0] | rw   | 16th conversion in regular sequence<br>These bits are set by software to define the channel number (0<br>~ 17) of the 16th conversion in the sequence.                                                                              |
| Bit 14:10 | SQ15[4:0] | rw   | 15th conversion in regular sequence                                                                                                                                                                                                 |
| Bit 9:5   | SQ14[4:0] | rw   | 14th conversion in regular sequence                                                                                                                                                                                                 |
| Bit 4:0   | SQ13[4:0] | rw   | 13th conversion in regular sequence                                                                                                                                                                                                 |

# 13.4.10 ADC Regular Sequence Register 2 (ADC\_RSQ2)

Address offset: 0x30

| Bit       | Name      | Туре | Description                                                                                           |
|-----------|-----------|------|-------------------------------------------------------------------------------------------------------|
| Bit 31:30 | -         | -    | Reserved. Must be kept as 0.                                                                          |
| Bit 29:25 | SQ12[4:0] | rw   | 12th conversion in regular sequence<br>These bits are set by software to define the channel number (0 |
|           |           |      | $\sim$ 17) of the 12th conversion in the sequence.                                                    |
| Bit 24:20 | SQ11[4:0] | rw   | 11th conversion in regular sequence                                                                   |
| Bit 19:15 | SQ10[4:0] | rw   | 10th conversion in regular sequence                                                                   |
| Bit 14:10 | SQ9[4:0]  | rw   | 9th conversion in regular sequence                                                                    |
| Bit 9:5   | SQ8[4:0]  | rw   | 8th conversion in regular sequence                                                                    |



# 13.4.11 ADC Regular Sequence Register 3 (ADC\_RSQ3)

Address offset: 0x34

Reset value: 0x0000 0000

| Bit       | Name     | Туре | Description                                                    |
|-----------|----------|------|----------------------------------------------------------------|
| Bit 31:30 | -        | -    | Reserved. Must be kept as 0.                                   |
|           |          |      | 6th conversion in regular sequence                             |
| Bit 29:25 | SQ6[4:0] | rw   | These bits are set by software to define the channel number (0 |
|           |          |      | $\sim$ 17) of the 6th conversion in the sequence.              |
| Bit 24:20 | SQ5[4:0] | rw   | 5th conversion in regular sequence                             |
| Bit 19:15 | SQ4[4:0] | rw   | 4th conversion in regular sequence                             |
| Bit 14:10 | SQ3[4:0] | rw   | 3rd conversion in regular sequence                             |
| Bit 9:5   | SQ2[4:0] | rw   | 2nd conversion in regular sequence                             |
| Bit 4:0   | SQ1[4:0] | rw   | 1st conversion in regular sequence                             |

# 13.4.12 ADC Injected Sequence Register (ADC\_JSQ)

Address offset: 0x38

| Bit                   | Name      | Туре            | Description                                                                                                                                                                                                                                                                   |
|-----------------------|-----------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31 <del>;22</del> | -         | _               | Reserved. Must be kept as 0.                                                                                                                                                                                                                                                  |
| Bit 21:20             | JLEN[1:0] | JSQ3[4:0]<br>rW | JSQ2[4:0]       JSQ1[4:0]         Injected sequence length         These bits are set by software to define the total number of         conversions in the injected channel conversion sequence.         00: 1 conversion         01: 2 conversions         10: 3 conversions |



|           |           |    | 11: 4 conversions                                                                                                |
|-----------|-----------|----|------------------------------------------------------------------------------------------------------------------|
| Bit 19:15 | JSQ4[4:0] | rw | 4th conversion in injected sequence                                                                              |
|           |           |    | These bits are set by software to define the channel number (0 $\sim$ 17) of the 4th conversion in the sequence. |
|           |           |    | Note: Unlike a regular conversion sequence, if the length of                                                     |
|           |           |    | JLEN[1:0] is less than four, the channels are converted in a                                                     |
|           |           |    | sequence starting from (4-JLEN). For example, ADC_JSQ[21:0]                                                      |
|           |           |    | = 10 00011 00011 00111 00010 means that the scan                                                                 |
|           |           |    | conversion will convert in the following channel sequence: 7, 3,                                                 |
|           |           |    | 3, instead of 2, 7, 3.                                                                                           |
| Bit 14:10 | JSQ3[4:0] | rw | 3rd conversion in injected sequence                                                                              |
| Bit 9:5   | JSQ2[4:0] | rw | 2nd conversion in injected sequence                                                                              |
| Bit 4:0   | JSQ1[4:0] | rw | 1st conversion in injected sequence                                                                              |

# 13.4.13 ADC Injected Data Register x (ADC\_JDORx) (x = 1...4)

Address offset: 0x3C - 0x48

| Bit       | Name     | Туре | Description                                                                                                                                                                                            |
|-----------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | -        | -    | Reserved. Must be kept as 0.                                                                                                                                                                           |
| Bit 15:0  | JD[15:0] | r    | Injected data<br>These bits are read only. They contain the conversion result of<br>the injected channels. The data will be left-aligned or right-<br>aligned as shown in Figure 13-6 and Figure 13-7. |



# 13.4.14 ADC Regular Data Register (ADC\_RDOR)

Address offset: 0x4C

| Bit       | Name    | Туре | Description                                                                                                                                                                                          |
|-----------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | -       | -    | Reserved.                                                                                                                                                                                            |
| Bit 15:0  | D[15:0] | r    | Regular data<br>These bits are read only. They contain the conversion result of<br>the regular channels. The data will be left-aligned or right-<br>aligned as shown in Figure 13-6 and Figure 13-7. |



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

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

I<sup>2</sup>C (inter-integrated circuit) bus interface serves as an interface between the microcontroller and the serial I<sup>2</sup>C bus. It provides multimaster capability and controls all I<sup>2</sup>C bus-specific sequencing, protocol, arbitration, and timing. It supports standard mode and fast mode, and is compatible with SMBus 2.0. I<sup>2</sup>C may be used for a variety of purposes, including CRC generation and verification, SMBus (system management bus), and PMBus (power management bus). According to the needs of specific devices, DMA can be utilized to reduce CPU overload.

# 14.2 I<sup>2</sup>C Main Features

- Parallel-bus/ I<sup>2</sup>C protocol converter
- Multimaster capability: The same interface can serve as master or slave.
- I<sup>2</sup>C Master features
  - Clock generation
  - Start and Stop signals generation
- I<sup>2</sup>C Slave features
  - Programmable I<sup>2</sup>C address detection
  - Dual addressing capability to acknowledge 2 slave addresses
  - Stop bit detection
- Generation and detection of 7-bit/10-bit addressing and general call
- Supports different communication speeds
  - Standard speed (Up to 100 kHz)
  - Fast speed (Up to 400 kHz)
- Status flags
  - Transmitter/Receiver mode flag
  - End-of-byte-transmission flag
  - I<sup>2</sup> C busy flag
- Error flags



- Arbitration lost in master mode
- Acknowledgment (ACK) failure after address/data transmission
- Detection of misplaced Start or Stop conditions
- Overrun/Underrun (If clock stretching is disabled)
- 2 interrupts vectors
  - 1 interrupt for successful address/data communication
  - 1 interrupt for error
- Optional clock stretching disable
- DMA with 1-byte buffer
- Configurable PEC (packet error checking) generation or verification
  - $-\,$  PEC value can be transmitted as the last byte in Tx mode
  - PEC error checking for the last received byte
- SMBus 2.0 compatibility
  - 25 ms clock low timeout delay
  - 10 ms master cumulative clock low extend time
  - 25 ms slave cumulative clock low extend time
  - Hardware PEC generation/verification with ACK control
  - Support Address Resolution Protocol (ARP)
- PMBus compatibility

# 14.3 I<sup>2</sup>C Function Overview

 $I^2C$  module receives and transmits data, and converts data from serial to parallel format, and vice versa. Interrupts can be enabled or disabled. The interface is connected to the  $I^2C$  bus through a data pin (SDA) and a clock pin (SCL). It is allowed to connect to a standard (up to 100 kHz) or a fast (up to 400 kHz)  $I^2C$  bus.

# 14.3.1 Mode Selection

The interface can operate in one of the following four modes:

• Slave transmitter mode



ango

- Master transmitter mode
- Master receiver mode

By default, the interface works in slave mode. After generating a Start condition, it automatically switches from slave mode to master mode. If an arbitration is lost or a Stop is generated, it switches from master mode to slave mode. It also has multimaster capability.

#### 14.3.1.1 Communication flow

In master mode, the I<sup>2</sup>C interface initiates data transfer and generates the clock signal. A serial data transfer always begins with a Start condition and ends with a Stop condition. Both Start and Stop conditions are generated in master mode by software.

In slave mode, the I<sup>2</sup>C interface can recognize its own addresses (7-bit or 10-bit) and the general call address. General call address recognition can be enabled or disabled by software.

Data and address are transferred as 8-bit (one byte), MSB first. The first or second byte following the Start condition is the address (one byte in 7-bit mode, two bytes in 10-bit mode). Addresses are always transmitted in master mode.

At the 9th clock period following the 8 clock cycles of a byte transfer, the receiver must send an acknowledge bit (ACK) to the transmitter. Please refer to Figure 14-1.

Figure 14-1 I<sup>2</sup>C Bus Protocol



Acknowledge (ACKEN) can be enabled or disabled by software, which can also set I<sup>2</sup>C interface addresses (7-bit, 10-bit, or general call address).

The block diagram of the I<sup>2</sup>C interface is shown in Figure 14-2.

Figure 14-2 Block Diagram of I<sup>2</sup>C Function





Note: SMBALERT is an optional signal in SMBus mode. This signal cannot be used if SMBus is disabled.

# 14.3.2 I<sup>2</sup>C Slave Mode

By default, the I<sup>2</sup>C interface operates in slave mode. To switch from slave mode to master mode, a Start condition generation is needed. In order to generate correct timings, the input clock of the module must be programmed in the I2C\_CTRL2 register. The input clock frequency must be at least:



- In standard mode: 2 MHz
- In fast mode: 4 MHz

As soon as a Start condition is detected, the address received from the SDA line is sent to the shift register. Then, it is compared with the address of the MCU, OADDR1 and OADDR2 (if DUALEN = 1), or the general call address (if GCEN = 1).

*Note: In 10-bit addressing mode, the comparison includes the header sequence (11110xx0), where xx denotes the two most significant bits of the address.* 

Header or address not matched: The I<sup>2</sup>C interface ignores it and waits for another Start condition.

**Header matched (10-bit mode only)**: If the ACKEN bit is set, the I<sup>2</sup>C interface generates an acknowledge pulse and waits for the 8-bit slave address.

**Address matched**: The I<sup>2</sup>C interface generates the following sequence:

- An acknowledge pulse is generated if the ACKEN bit is set.
- The ADDRF bit is set by hardware; an interrupt is generated if the EVTITEN bit is set.

• If DUALEN = 1, the software must read the DUALF bit to see which slave address is acknowledged.

In 10-bit mode, after receiving the address sequence, the slave is always in receiver mode. It will enter transmitter mode when receiving a repeated Start condition, followed by the header sequence matching the address, and the least significant bit set (11110xx1).

In slave mode, the TRF bit indicates whether the slave is in receiver or transmitter mode.

#### 14.3.2.1 Slave transmitter

After the address is received and the ADDRF bit is cleared, the slave transmitter sends bytes from the DT register to the SDA line via the internal shift register.

The slave stretches SCL low until the ADDRF bit is cleared, and the data to be sent is written into the DT register. (Please refer to EV1 and EV3 in Figure 14-3.)

When the acknowledge pulse is received:

• The TDE bit is set by hardware. An interrupt is generated if the EVTITEN and BUFITEN bits are set.

If the TDE bit is set, but there is no new data written into the I2C\_DT register before the end of the next data transmission, then the BTFF bit is set. The I<sup>2</sup>C interface stretches SCL low until the BTFF bit is



cleared. A read to I2C\_STS1 followed by a write to the I2C\_DT register will clear the BTFF bit.

7-bit slave transmitter s Address А Data 1 А Data 2 Data N NA Ρ EV1 EV3-1 EV3 EV3 EV3 EV3-2 10-bit slave transmitter Header Address S А А EV1 Header А Data 1 Data N NA P S EV1 EV3\_1 EV3 EV3 EV3-2 Description: S = Start (Start condition), Sr = Repeated start condition, P = Stop (Stop condition), A = Acknowledge, NA = Non acknowledge, Evx = Event (Interrupt generated when EVTITEN = 1) EV1: ADDRF = 1, read STS1 and then STS2 to clear the event. EV3-1: TDE = 1, the shift register empty, the data register empty, write DT. EV3: TDE = 1, the shift register not empty, the data register empty, cleared by writing DT. EV3-2: ACKFAIL = 1, ACKFAIL is cleared by writing '0' to the ACKFAIL bit in the STS1 register. Note: 1. EV1 and EV3\_1 events stretch SCL low until the corresponding software sequence ends. 2. EV3 software sequence must be completed before the end of the current byte transfer.

Figure 14-3 Transfer Sequence Diagram of Slave Transmitter

# 14.3.2.2 Slave receiver

After the address is received and the ADDRF bit is cleared, the slave receiver stores bytes received from the SDA line via the internal shift register into the DT register.

The I<sup>2</sup>C interface operates as follows after each byte reception:

- An acknowledge pulse is generated if the ACKEN bit is set.
- Set RDNE = 1 by hardware. An interrupt is generated if the EVTITEN and BUFITEN bits are set.

If RDNE is set, and the data in the DT register is not read before the end of the next data reception, then the BTFF bit is set. The I<sup>2</sup>C interface stretches SCL low until BTFF is cleared. A read to I2C\_STS1 followed by a read to the I2C\_DT register will clear the BTFF bit.

Figure 14-4 Transfer Sequence Diagram of Slave Receiver





# 14.3.2.3 Closing slave communication

After the last data byte is transferred, a Stop condition is generated by the master. When the I<sup>2</sup>C interface detects this condition:

• Set the STOPF bit = 1 and generate an interrupt if the EVTITEN bit is set.

Then, the I<sup>2</sup>C interface waits for reading the STS1 register, followed by writing to CTRL1 register. After this operation is completed, the STOPF bit is cleared (Please refer to EV4 in Figure 14-4).

# 14.3.3 I<sup>2</sup>C Master Mode

In master mode, the I<sup>2</sup>C interface initiates data transfer and generates the clock signal. A serial data transfer always begins with a Start condition and ends with a Stop condition. When a Start condition is generated on the bus through the STARTGEN bit, the device enters master mode.

The sequence required in master mode is as follows:

- Program the input clock in the I2C\_CTRL2 register to generate correct timings.
- Configure the clock control registers
- Configure the rise time register
- Program the I2C\_CTRL1 register to enable the peripheral
- Set the STARTGEN bit in the I2C\_CTRL1 register to generate a Start condition

The frequency of  $I^2C$  input clock must be at least:



- In standard mode: 2 MHz
- In fast mode: 4 MHz

#### 14.3.3.1 Master clock generation

CLKCTRL is used to generate the high and low level of the I<sup>2</sup>C clock, starting from the rising and falling edges of the clock. Since a slave may stretch the SCL line, the peripheral will check the level of the clock line after the maximum rising edge generation time programmed in the TMRISE register.

• If the clock line is low, it means that a slave is stretching the bus, and the high level counter stops until the clock line is detected high. This guarantees the HIGH period of the SCL clock.

• If the clock line is high, the high level counter keeps counting.

#### 14.3.3.2 Start condition

Set the STARTGEN = 1 when BUSYF = 0, and the  $I^2C$  interface will generate a Start condition and switch to master mode (the MSF bit is set).

Note: In master mode, setting the STARTGEN bit will generate a re-Start condition by hardware at the end of the current byte transfer.

Once the Start condition is generated:

The STARTF bit is set by hardware. An interrupt is generated if the EVTITEN bit is set. Then, the master waits for a read to the STS1 register, followed by writing the slave address into the DTregister (Please refer to EV5 in Figure 14-5 and Figure 14-6).

#### 14.3.3.3 Slave address transmission

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

- In 10-bit addressing mode, sending the header sequence generates the following events:
  - The ADDR10F bit is set by hardware, and an interrupt is generated if the EVTITEN bit is set.

Then, the master waits for a read to the STS1 register, and then writes the second address byte into the DT register (Please refer to Figure 14-5 and Figure 14-6).

- The ADDRF bit is set by hardware, and an interrupt is generated if the EVTITEN bit is set.

Then, the master waits for a read to the STS1 register, and then a read to the STS2 register (Please refer to Figure 14-5 and Figure 14-6).



- In 7-bit addressing mode, only one address byte is sent. As soon as the address byte is sent,
  - $-\,$  The ADDRF bit is set by hardware, and an interrupt is generated if the EVTITEN bit is set.

Then, the master waits for a read to the STS1 register, and then a read to the STS2 register (Please refer to Figure 14-5 and Figure 14-6).

The master can decide to enter transmitter or receiver mode according to the LSB of the slave address sent.

- In 7-bit addressing mode
  - To enter transmitter mode, a master sends the slave address with LSB reset.
  - To enter receiver mode, a master sends the slave address with LSB set.
- In 10-bit addressing mode

- To enter transmitter mode, a master first sends the header (11110xx0), and then the slave address (where xx denotes the two most significant bits of the 10 -bit address).

To enter receiver mode, a master first sends the header (11110xx0), and then the slave address.
 Then, it resends a repeated Start condition followed by the header (11110xx1), (where xx denotes the

two most significant bits of the 10 -bit address).

The TRF bit indicates whether the master is in receiver or transmitter mode.

#### 14.3.3.4 Master transmitter

After address is transferred and the ADDRF bit is cleared, the master sends bytes from the DT register to the SDA line via the internal shift register.

The master waits until the data is written into the DT register and TDE is cleared (Please refer to EV8 in Figure 14-5).

When the acknowledge pulse is received:

• The TDE bit is set by hardware, and an interrupt is generated if the EVTITEN and BUFITEN bits are set.

If TDE is set and there is no new data byte written into the DT register before the end of the last data transmission, then BTFF is set by hardware. The interface stretches SCL low until BTFF is cleared. BTFF is cleared by a read to I2C\_STS1 followed by a write to I2C\_DT.



## 14.3.3.5 Closing the communication

After the last byte is written to the DT register, the STOPGEN bit is set to generate a Stop condition (please refer to EV8\_2 in Figure 14-5). Then, the I<sup>2</sup>C interface automatically returns to slave mode (the MSF bit is cleared).

*Note: Stop condition should be programmed during EV8\_2 event when either the TDE bit* or the BTFF bit is set.



Figure 14-5 Transfer Sequence Diagram of Master Transmitter

## 14.3.3.6 Master receiver

After the address is transmitted, and ADDRF is cleared, the I<sup>2</sup>C interface enters master receiver mode. In this mode, the I<sup>2</sup>C interface receives data bytes from the SDA line and sends them into the DT register via the internal shift register. After each byte, the I<sup>2</sup>C interface generates the following in sequence:

- An acknowledge pulse is sent if the ACKEN bit is set.
- Set RDNE = 1 by hardware. An interrupt is generated if the EVTITEN and BUFITEN bits are set (Please refer to EV7 in Figure 14-6).

If the RDNE bit is set, and the data in the DT register is not read before the end of the last data reception, the BTFF bit will be set by hardware. The I<sup>2</sup>C interface stretches SCL low until BTFF is cleared. BTFF is cleared by a read to I2C\_STS1 followed by a read to I2C\_DT.



## 14.3.3.7 Closing the communication

**Case 1:** I<sup>2</sup>C interrupt is set as the highest priority.

The master sends a NACK after the last byte is received from the slave. After receiving the NACK, the slave releases the control on the SCL and SDA lines. Then, the master can send a Stop/re-Start condition.

• To generate a NACK pulse after the last data byte is received, the ACKEN bit must be cleared after reading the second last data byte (after the second last RDNE event).

• To generate a Stop/re-Start condition, software must set the STOPGEN/STARTGEN bit after reading the second last data byte (after the second last RDNE event).

• When only a single byte is received, the generation bits of acknowledge and set condition should be disabled right after EV6 (in EV6\_1, after ADDRF is cleared).

After the Stop condition is generated, the I<sup>2</sup>C interface returns to slave mode automatically (The MSF bit is cleared).

Figure 14-6 Transfer Sequence Diagram of Master Receiver



Note: 1. If a single byte is received, it is NA.

2. The EV5, EV6, and EV9 events stretch SCL low until the end of the corresponding software

sequence.

3. The EV7 software sequence must be completed before the end of the current byte transfer.

4. The EV6\_1 or EV7\_1 software sequence must be completed before the ACK pulse of the current



Hangzhou Vango Technologies, Inc.

byte transfer.

**Case 2:**  $I^2C$  interrupt is not set as the highest priority, and the total number of bytes received is more than 2, N > 2.

In this case, data N-2 received is not read; after data N-1 is received, the clock is stretched, and communication is stopped. At this time, clear the ACKEN bit and then read data N-2 one by one. After that, set STOPGEN/STARTGEN and read data N-1. Wait until RDNE is set, read data N. This is illustrated in Figure 14-7:



Figure 14-7 Transfer Sequence Diagram for Master Receiver when N > 2

When 3 bytes are left to be read, software procedure is as follows:

- RDNE = 1 => No action
- Data N-1 received
- BTFF = 1, N-2 in DT, N-1 in the shift register, clock stretched low
- Clear the ACKEN bit
- Read data N-2, and the bus starts receiving data N
- Data N received, and respond to NACK
- Set the STARTGEN/STOPGEN bit
- RDNE = 1
- Read data N

**Case 3:** I<sup>2</sup>C interrupt is not set as the highest priority, and the total number of bytes received is 2 or 1,

N = 2 or N = 1

- Receiving a single byte
  - Clear the ACKEN bit at ADDRF event
  - Clear the ADDRF bit
  - Set the STARTGEN/STOPGEN bit
  - $-\,$  Read data when the RDNE bit is set
- Receiving two bytes
  - Set the POSEN and ACKEN bits
  - $-\,$  Wait for the ADDRF bit to be set
  - Clear the ADDRF bit
  - Clear the ACKEN bit
  - $-\,$  Wait for BTFF to be set
  - Set the STOPGEN bit
  - Read the DT register twice

#### Figure 14-8 Transfer Sequence Diagram for Master Receiver when N = 2









# 14.3.4 Error Condition

The following error conditions may cause communication fail.

# 14.3.4.1 Bus error (BUSERR)

Bus error occurs when the I<sup>2</sup>C interface detects an external Stop or Start condition during an address or a data transfer. In this case:

- The BUSERR bit is set; an interrupt is generated if the ERRITEN bit is set.
- In slave mode, data are discarded, and the bus is released by hardware.
  - $-\,$  If it is a misplaced Start, the slave should clear the BUSERR bit and wait for the next Start.
  - If it is a misplaced Stop, the slave works normally for a Stop condition, and the bus is released by hardware at the same time.
- In master mode, the bus is not released by hardware, and the state of the current transmission is not affected. Whether to stop the current transmission is determined by the software.

## 14.3.4.2 Acknowledge failure (ACKFAIL)

Acknowledge failure occurs when the interface detects a non-acknowledge bit. In this case:

- The ACKFAIL bit is set; an interrupt is generated if the ERRITEN bit is set.
- When the transmitter receives a NACK, the communication must be reset.
  - $-\,$  If it is in slave mode, the bus is released by hardware.
  - If it is in master mode, a Stop or repeated Start condition must be generated by software.

## **14.3.4.3** Arbitration lost (ARLOST)

Arbitration lost occurs when the I<sup>2</sup>C interface detects an arbitration lost condition. In this case:

• The ARLOST bit is set by hardware; an interrupt is generated if the ERRITEN bit is set.

• The I<sup>2</sup>C interface automatically returns to slave mode (the MSF bit is cleared). When the I<sup>2</sup>C interface loses the arbitration, it cannot acknowledge its slave address in the same transfer. However, it can acknowledge after the master, which wins the bus, transmits a repeated Start.

Bus is released by hardware.

#### 14.3.4.4 Overrun/underrun error (OVRUN)

In slave mode, an overrun error occurs if clock stretching is disabled, the  $I^2C$  interface receives a byte (RDNE = 1) when receiving data, but the last byte data is not yet read in the DT register. In this case:

• The last received byte is lost.

• In overrun error, software should clear the RDN bit, and the transmitter should re-transmit the last received byte.

In slave mode, an underrun error occurs if clock stretching is disabled, the  $I^2C$  interface is transmitting data, but before the clock of the next byte arrives, new data is not yet written into the DT register (TDE = 1). In this case:

• The last byte in the DT register will be sent again.

• Users should ensure that when an underrun error occurs, repeated data received on the receiver side should be discarded. The transmitter side should update the DT register within the time specified by the I<sup>2</sup>C bus standard.

When the first byte is to be transmitted, the DT register must be written after ADDRF is cleared and before the first SCL rising edge. If this is not possible, the receiver must discard the first data.

# **14.3.5 SDA/SCL Line Control**

• If clock stretching is enabled:

- Transmitter mode: If TDE = 1 and BTFF = 1: The I<sup>2</sup>C interface holds the clock line low before transmission, to wait for the software to read STS1 and then write the data into the data register (both the buffer and the shift register are empty).



- Receiver mode: If RDNE = 1 and BTFF = 1: The I<sup>2</sup>C interface holds the clock line low after data reception, to wait for the software to read STS1 and then read data in the data register, DT (both the buffer and the shift register are full).

• If clock stretching is disabled in slave mode:

If RDNE = 1, an overrun error occurs when DT is not read yet before the next byte is received. The last received byte is lost.

- If TDE = 1, an underrun error occurs when no new data is written to DT before the next byte should be sent. The same byte will be sent again.

Write collision is not controlled.

# 14.3.6 SMBus

## 14.3.6.1 Introduction

The System Management Bus (SMBus) is a 2-wire interface through which various devices can communicate with each other and with the rest of the system. It is based on I<sup>2</sup>C. SMBus provides a control bus for system and power management related tasks. A system may use SMBus to send messages to and from devices instead of individual control lines.

The System Management Bus (SMBus) Specification refers to three types of devices. A slave is a device that receives or responds to a command. A master is a device that issues commands, generates the clocks, and terminates the transfer. A host is a specialized master that provides the main interface to the CPU of the system. A host must have master-slave capability and must support the SMBus host notify protocol. Only one host is allowed in a system.

## 14.3.6.2 Similarities between SMBus and I<sup>2</sup>C

- 2-wire bus protocol (1 clock, 1 data) + optional SMBus al ert line
- Master-slave communication, master provides clocks
- Multi-master capability
- SMBus data format similar to I<sup>2</sup>C 7-bit addressing format (Please refer to Figure 14-1)

## 14.3.6.3 Differences between SMBus and I<sup>2</sup>C

Table 14-1 lists the differences between SMBus and I<sup>2</sup>C.



| Table 14-1 Compariso | n between SMBus and I <sup>2</sup> C |
|----------------------|--------------------------------------|
|----------------------|--------------------------------------|

| SMBus                                                 | I <sup>2</sup> C                              |
|-------------------------------------------------------|-----------------------------------------------|
| Max. speed of 100 kHz                                 | Max. speed of 400 kHz                         |
| Min. speed of 10 kHz                                  | No minimum speed                              |
| 35 ms clock low timeout                               | No clock timeout                              |
| Fixed logic levels                                    | VDD-dependent logic levels                    |
| Different address types (reserved, dynamic, etc.)     | 7-bit, 10-bit, and general call slave address |
|                                                       | types                                         |
| Different bus protocols (quick command, process call, | No bus protocols                              |
| etc.)                                                 |                                               |

# 14.3.6.4 SMBus applications

With System Management Bus, devices can provide manufacturer information, tell the system its model/part number, save its state for a suspend event, report different types of errors, accept control parameters, and return its status. SMBus provides a control bus for system and power management related tasks.

## 14.3.6.5 Device identification

Any device on the System Management Bus as a slave has a unique address called the "slave address." For the list of reserved slave addresses, please refer to the SMBus specification version 2.0 (*http://smbus.org/specs/*).

## 14.3.6.6 Bus protocols

The SMBus specification supports up to 9 bus protocols. For more details on these protocols and SMBus address types, please refer to SMBus specification version 2.0. (<u>http://smbus.org/specs/</u>). These protocols should be implemented by the user software.

## 14.3.6.7 Address resolution protocol (ARP)

SMBus slave address conflicts can be resolved by dynamically assigning a new unique address to each slave device. The Address Resolution Protocol (ARP) has the following features:

• Address assignment with the standard SMBus physical layer arbitration mechanism



Hangzhou Vango Technologies, Inc.

• Assigned addresses remain constant while device power is applied; address retention after device power loss is also allowed.

- No additional SMBus packet overhead is incurred after address assignment. (i.e. subsequent accesses to assigned slave addresses have the same overhead as accesses to fixed address devices.)
- Any SMBus master can enumerate the bus.

# 14.3.6.8 Unique device identifier (UDID)

In order to assign addresses, a mechanism to isolate each device is needed. Each device must implement a unique device identifier.

For more details on the 128-bit UDID on ARP, please refer to SMBus specification version 2.0. (*http://smbus.org/specs/*). (UDID)

## 14.3.6.9 SMBus alert mode

SMBus Alert is an optional signal with an interrupt line, and it is used for devices that trade a pin for extending their control ability. SMBALERT, as well as SCL and SDA signals, is a wired-AND signal. SMBALERT is usually used with the SMBus General Call Address. Messages invoked with the SMBus are two bytes long.

A slave-only device can use SMBALERT to signal the host through the SMBALERT bit of I2C\_CTRL1 register, showing its intention to communicate. The host then processes the interrupt and accesses all SMBALERT devices through the Alert Response Address, ARA (Alert Response Address, its address is 0001100x). Only the device(s) which pull SMBALERT low can acknowledge ARA. This status is identified by the SMBALERTF Status flag in the I2C\_STS1 register. The host performs a modified Receive Byte operation. The 7-bit device address provided by the slave transmission device is placed in the 7 most significant bits of the byte. The eighth bit can be a '0' or'1'.

If more than one device pulls SMBALERT low, the device with the highest priority (lowest address) will win the communication via standard arbitration during the address transfer. After acknowledging the slave address, the device must disengage its SMBALERT pull-down. If the host still sees SMBALERT low when the message transfer is completed, it knows that ARAshould be read again.

A host which does not implement the SMBALERT signal can periodically access ARA.

For more details on SMBus Alert mode, please refer to SMBus specification version 2.0. standard (<u>http://smbus.org/specs/)</u>.



## 14.3.6.10 Timeout error

In the timing specifications, there are several differences between I<sup>2</sup>C and SMBus.

SMBus defines a clock low timeout, TIMEOUT of 35 ms. SMBus specifies TLOW: SEXT as the cumulative clock low extend time for a slave device. SMBus specifies TLOW: MEXT as the cumulative clock low extend time for a master device. For more details on these timeouts, please refer to SMBus specification version 2.0. standard (*http://smbus.org/specs/*).

The status flag Timeout or Tlow Error in I2C\_STS1 shows the status of this feature.

## 14.3.6.11 How to use the interface in SMBus mode

To switch from I<sup>2</sup>C mode to SMBus mode, the following sequence should be performed:

- Set the SMBMODE bit in the I2C\_CTRL1 register
- Configure the SMBTYPE and ARPEN bits in the I2C\_CTRL 1 register as the application required.

If the device is to be configured as a master, follow the Start condition generation procedure in Section

14.3.3. Otherwise, follow Section 14.3.2.

The software application should handle various SMBus protocols.

- SMB Device Default Address acknowledged if ARPEN = 1 and SMBTYPE = 0
- SMB Host Header acknowledged if ARPEN = 1 and SMBTYPE = 1
- SMB Alert Response Address acknowledged if SMBALERTF = 1

## 14.3.7 DMA Request

DMA requests (when enabled) are only for data transfer. DMA requests are generated when the data register becomes empty in transmission or becomes full in reception. The DMA requests must be acknowledged before the end of current byte transfer. When the number of data transfers, which has been programmed for the corresponding DMA channel, is reached, the DMA controller sends an End of

Transfer signal, EOT, to the I<sup>2</sup>C interface, and generates a Transfer Complete interrupt if enabled:

 Master transmitter: In the EOT interrupt routine, DMA requests should be disabled, and then wait for a BTFF event before programming the Stop condition.



Master receiver: When the number of bytes to be received is equal to or greater than two, the DMA controller sends a hardware signal, EOT\_1, corresponding to DMA transfer (number of bytes – 1). If the DMALAST bit is set in the I2C\_CTRL2 register, the hardware automatically sends a NACK after the next byte following EOT\_1. Users can generate a Stop condition in the DMA Transfer Complete interrupt routine if enabled.

#### 14.3.7.1 Transmission using DMA

DMA mode can be enabled by setting the DMAEN bit in the I2C\_CTRL2 register. Once the TDE bit is set, data will be loaded from the programmed Memory to the I2C\_DT register through DMA. To assign a DMA channel for I<sup>2</sup>C, perform the following sequence (where x is the channel number):

1. Set the I2C\_DT register address in the DMA\_CPBAx register. The data will be sent to this address from the memory after each TDE event.

2. Set the memory address in the DMA\_CMBAx register. The data will be sent to I2C\_DT from this memory after each TDE event.

3. Configure the total number of bytes to be transferred in the DMA\_TCNTx register. After each TDE event, this value will be decremented.

4. Configure the channel priority by the CHPL[0:1] bits in the DMA\_CHCTRLx register.

5. Set the DIR bit in the DMA\_CHCTRLx register and configure interrupt requests to be sent after half transfer or full transfer according to the application requirements.

6. Activate the channel by setting the CHEN bit in the DMA\_CHCTRLx register.

When the number of data transfers, programmed in the DMA controller, is reached, the DMA controller sends an End of Transfer signal, EOT/EOT\_1, to the I<sup>2</sup>C interface. A DMA interrupt will be generated if enabled.

Note: Do not set the BUFITEN bit in the I2C\_CTRL2 register if DMA is used for transmission.

### 14.3.7.2 Reception using DMA

DMA mode can be enabled for reception by setting the DMAEN bit in the I2C\_CTRL2 register. Whenever a data byte is received, data will be sent from the I2C\_DT register to the programmed Memory area through DMA (Please refer to DMA description). To set DMA channel for I<sup>2</sup>C reception, perform the following sequence (where x is the channel number):

1. Set the I2C\_DT register address in the DMA\_CPBAx register. The data will be sent from this address



to the memory after each RDNE event.

2. Set the memory address in the DMA\_CMBAx register. The data will be sent from the I2C\_DT register to this memory after each RDNE event.

3. Configure the total number of bytes to be transferred in the DMA\_TCNTx register. After each RDNE event, this value will be decremented.

4. Configure the channel priority by the CHPL[0:1] bits in the DMA\_CHCTRLx register.

5. Set the DIR bit in the DMA\_CHCTRLx register and configure interrupt requests to be sent after half transfer or full transfer according to the application requirements.

6. Activate the channel by setting the CHEN bit in the DMA\_CHCTRLx register.

When the number of data transfers, programmed in the DMA controller, is reached, the DMA controller sends an End of Transfer signal, EOT/EOT\_1, to the I<sup>2</sup>C interface. A DMA interrupt will be generated if enabled.

Note: Do not set the BUFITEN bit in the I2C\_CTRL2 register if DMA is used for reception.

#### 14.3.8 Packet Error Checking (PEC)

A packet error checking (PEC) calculator can improve the reliability of communication. The calculator calculates by using the following polynomial on each bit serially.

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

• PEC calculation is enabled by setting the PECEN bit in the I2C\_CTRL1 register. PEC calculates with CRC-8 computation on all message bytes, including addresses and R/W bits.

 In transmission: Set the PECTRA transfer bit in the I2C\_CTRL1 register after the last TDE event. PEC will be transferred after the last transmitted byte.

— In reception: Set the PECTRA bit in the I2C\_CTRL1 register after the last RDNE event. If the next received byte is not equal to the internally calculated PECVAL, the receiver sends a NACK. No matter what the checking results is, a NACK is always sent after PEC. The PECTRA bit must be set before the ACK pulse of the current byte is received.

• A PECERR error flag/interrupt is available in the I2C\_STS1 register.

If DMA and PEC calculator are both enabled:

In transmission: When the I<sup>2</sup>C interface receives an EOT signal from the DMA controller, it



automatically sends PECVAL after the last byte.

- In reception: When the I<sup>2</sup> C interface receives an EOT\_1 signal from the DMA controller, it will automatically consider the next byte as PECVAL and check it. A DMA request is generated after PECVAL is received.

• To allow intermediate PEC transfers, a control bit (the DMALAST bit) is available in the I2C\_CTRL2 register to determine if it is really the last DMA transfer. If it is the last DMA request for a master receiver, a NACK is automatically sent after the last received byte.

• PEC calculation is corrupted when arbitration is lost.

#### 14.3.9 I<sup>2</sup>C Interrupt Request

Table 14-2 lists all the I<sup>2</sup>C interrupt request.

| Interrupt Event                          | Event Flag | Enable Control Bit  |
|------------------------------------------|------------|---------------------|
| Start bit sent (Master)                  | STARTF     | EVTITEN             |
| Address sent (Master) or Address matched | ADDRF      |                     |
| (Slave)                                  |            |                     |
| 10-bit header sent (Master)              | ADDR10F    |                     |
| Stop received (Slave)                    | STOPF      |                     |
| Data byte transfer finished              | BTFF       |                     |
| Receive buffer not empty                 | RDNE       | EVTITEN and BUFITEN |
| Transmit buffer empty                    | TDE        |                     |
| Bus error                                | BUSERR     | ERRITEN             |
| Arbitration loss (Master)                | ARLOST     |                     |
| Acknowledge failure                      | ACKFAIL    |                     |
| Overrun/Underrun                         | OVRUN      |                     |
| PEC error                                | PECERR     |                     |
| Timeout/Tlow error                       | TIMOUT     |                     |

Table 14-2 I<sup>2</sup>C Interrupt Request



| SMBus Alert | SMBALERTF |  |
|-------------|-----------|--|
|-------------|-----------|--|

Note: 1. STARTF, ADDRF, ADDR10F, STOPF, BTFF, RDNE, and TDE are logically OR-ed on the same interrupt channel.

2. BUSERR, ARLOST, ACKFAIL, OVRUN, PECERR, TIMOUT, and SMBALERTF are logically OR-ed on the same interrupt channel.

Figure 14-10 I<sup>2</sup>C Interrupt Mapping Diagram



### 14.3.10 I<sup>2</sup>C Debug Mode

When the microcontroller enters debug mode (Cortex<sup>®</sup>-M4F core halted), the SMBUS timeout either



continues to work normally or stops, depending on the DBG\_I2Cx\_SMBUS\_TIMEOUT configuration bits in the DBG module. For more details, please refer to <u>Section 20.2.2</u>.

# 14.4 I<sup>2</sup>C Registers

# 14.4.1 Control Register 1 (I2C\_CTRL1)

Address offset: 0x00

| Bit    | Name     | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15 | SWRESET  | rw   | Software reset<br>When set, I <sup>2</sup> C is under reset state. Before resetting this bit,<br>ensure that I <sup>2</sup> C pins are released, and the bus is free.<br>0: I <sup>2</sup> C peripheral is not at reset state.<br>1: I <sup>2</sup> C peripheral is at reset state.<br>Note: This bit can be used when the BUSYF bit is '1', and no<br>Stop condition is detected<br>on the bus. |
| Bit 14 | -        | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                                                                                                                          |
| Bit 13 | SMBALERT | rw   | <ul> <li>SMBus alert</li> <li>This bit is set or cleared by software. It is cleared by</li> <li>hardware when PEN = 0.</li> <li>0: Release SMBAlert pin high. Alert Response Address</li> <li>Header follows the NACK signal.</li> <li>1: Drive SMBAlert pin low. Alert Response Address Header</li> <li>follows the ACK signal.</li> </ul>                                                      |
| Bit 12 | PECTRA   | rw   | Packet error checking<br>This bit is set or cleared by software. It is cleared by<br>hardware after PECVAL is sent, or under Stop/Start<br>condition.                                                                                                                                                                                                                                            |



|               |         |                                    | 0: No PEC transfer                                             |
|---------------|---------|------------------------------------|----------------------------------------------------------------|
|               |         |                                    | 1: PEC transfer (in transmitter or receiver mode)              |
|               |         |                                    | Note: PEC calculation is corrupted when arbitration is lost.   |
|               |         |                                    | Acknowledge/PEC Position (for data reception) This bit is set  |
|               |         |                                    | or cleared by software.                                        |
|               |         |                                    | 0: The ACKEN bit controls (N)ACK of the current byte being     |
|               |         |                                    | received in the shift register. The PECTRA bit indicates that  |
|               |         |                                    | the current byte in shift register is PECVAL.                  |
|               |         |                                    | 1: The ACKEN bit controls (N)ACK of the next byte to be        |
|               |         |                                    | received in the shift register. The PECTRA bit indicates that  |
| Bit 11        | POSEN   | rw                                 | the next byte received in the shift register is PECVAL.        |
|               |         |                                    | Note: The POSEN bit is used only for reception of 2 bytes. It  |
|               |         |                                    | must be configured before data reception starts. To NACK       |
|               |         |                                    | the 2nd byte, the ACKEN bit must be cleared after ADDRF is     |
|               |         |                                    | cleared. To check the PECVAL bit of the 2nd byte, the          |
|               |         |                                    | PECTRA bit should be set after the POSEN bit is set, during    |
|               |         |                                    | ADDR and event stretch.                                        |
|               |         | rw                                 | Acknowledge enable                                             |
|               |         |                                    | This bit is set or cleared by software.                        |
| Bit 10        | ACKEN   |                                    | 0: No acknowledge returns.                                     |
|               |         |                                    | 1: Acknowledge returns after a byte is received (matched       |
|               |         |                                    | address or data).                                              |
|               |         |                                    |                                                                |
|               |         |                                    | Stop generation                                                |
|               |         |                                    | This bit is set or cleared by software. It is cleared by       |
|               |         |                                    | hardware when a Stop condition is detected. It is set by       |
| Bit 9 STOPGEN |         |                                    | hardware when a timeout error is detected.                     |
|               | STOPGEN | rw                                 | In master mode:                                                |
|               |         | 0: No Stop condition is generated. |                                                                |
|               |         |                                    | 1: Stop condition is generated after the data register and the |
|               |         |                                    | shift register complete transfer or after the current Start    |
|               |         |                                    | condition is sent.                                             |
|               |         |                                    | In slave mode:                                                 |

|       |              |                    | 0: No Stop condition is generated.                             |
|-------|--------------|--------------------|----------------------------------------------------------------|
|       |              |                    | 1: Release the SCL and SDA lines after the current byte        |
|       |              |                    | transfer.                                                      |
|       |              |                    | Note: If the STOPGEN, STARTGEN, or PECTRA bit is set, do       |
|       |              |                    | not perform any write access to I2C_CTRL1 before this bit is   |
|       |              |                    | cleared by hardware. Otherwise, the STOPGEN, STARTGEN,         |
|       |              |                    | or PECTRA bit may be set for the second time.                  |
|       |              |                    | Start generation                                               |
|       |              |                    | This bit is set or cleared by software. It is cleared by       |
|       |              |                    | hardware when a Start condition is sent.                       |
|       |              |                    | In master mode:                                                |
| Bit 8 | STARTGEN     | rw                 | 0: No Start condition is generated.                            |
|       |              |                    | 1: Start condition is generated repeatedly.                    |
|       |              |                    | In slave mode:                                                 |
|       |              |                    | 0: No Start condition is generated.                            |
|       |              |                    | 1: Start condition is generated when the bus is free.          |
|       |              | rw                 | Clock stretching disable (Slave mode)                          |
|       |              |                    | This bit is used to disable clock stretching in slave mode     |
| Bit 7 | NOCLKSTRETCH |                    | when ADDRF or BTFF flag is set, until it is reset by software. |
|       |              |                    | 0: Clock stretching is enabled.                                |
|       |              |                    | 1: Clock stretching is disabled.                               |
|       |              |                    | General call enable                                            |
| Bit 6 | GCEN         | rw                 | 0: General call disabled. Address 00h is NACKed.               |
|       |              |                    | 1: General call enabled. Address 00h is ACKed.                 |
|       |              |                    | PEC enable                                                     |
| Bit 5 | PECEN        | rw                 | 0: PEC calculation is disabled.                                |
|       |              | 1.00               | 1: PEC calculation is enabled                                  |
|       |              |                    | ARP enable                                                     |
|       |              |                    |                                                                |
| Bit 4 | Bit 4 ARPEN  | rw                 | 0: ARP is disabled.                                            |
|       |              | 1: ARP is enabled. |                                                                |
|       |              |                    | If SMBTYPE = 0, SMBus device default address is recognized.    |



|       |         |    | If SMBTYPE = 1, SMBus host address is recognized.                            |
|-------|---------|----|------------------------------------------------------------------------------|
|       |         |    | SMBus type                                                                   |
| Bit 3 | SMBTYPE | rw | 0: SMBus device                                                              |
|       |         |    | 1: SMBus host                                                                |
| Bit 2 | -       | -  | Reserved. Forced to be '0' by hardware.                                      |
|       |         |    | SMBus mode                                                                   |
| Bit 1 | SMBMODE | rw | 0: I <sup>2</sup> C mode                                                     |
|       |         |    | 1: SMBus mode                                                                |
|       |         |    | Peripheral enable                                                            |
|       |         | rw | 0: I <sup>2</sup> C peripheral is disabled.                                  |
|       |         |    | 1: I <sup>2</sup> C peripheral is enabled. According to the configuration of |
|       |         |    | the SMBus bit, the corresponding I/O port should be                          |
|       |         |    | configured as Alternate Function.                                            |
| Bit 0 | PEN     |    | Note: 1. If this bit is reset while a communication is ongoing,              |
|       |         |    | the I <sup>2</sup> C peripheral is disabled at the end of the current        |
|       |         |    | communication, and return to IDLE state.                                     |
|       |         |    | 2. All bits are reset as $PE = 0$ at the end of the                          |
|       |         |    | communication.                                                               |
|       |         |    | 3. In master mode, this bit must not be reset before the end                 |
|       |         |    | of the communication.                                                        |

*Note: When the STARTGEN, STOPGEN, or PECTRA bit is set, the software must write* to I2C\_CTRL1 after the corresponding bit is cleared by hardware. Otherwise, there is a risk of generating a second STARTGEN, STOPGEN, or PECTRA request.

# 14.4.2 Control Register 2 (I2C\_CTRL2)

Address offset: 0x04

| Bit       | Name | Туре | Description                             |
|-----------|------|------|-----------------------------------------|
| Bit 15:13 | -    | -    | Reserved. Forced to be '0' by hardware. |



|               |                |                               | DMA last transfer                                            |
|---------------|----------------|-------------------------------|--------------------------------------------------------------|
|               |                |                               | 0: The next DMA EOT is not the last transfer.                |
| Bit 12        | Bit 12 DMALAST | rw                            | 1: The next DMA EOT is the last transfer.                    |
|               |                |                               | Note: This bit is used in master receiver mode to permit the |
|               |                |                               | generation of a NACK at the last data reception.             |
|               |                |                               | DMA requests enable                                          |
| Bit 11        | DMAEN          | rw                            | 0: DMA request is disabled.                                  |
|               |                |                               | 1: DMA request is enabled when TDE = 1 or RDNE = 1.          |
|               |                |                               | Buffer interrupt enable                                      |
|               | DULETTEN       | -                             | 0: No interrupt is generated when $TDE = 1$ or $RDNE = 1$ .  |
| Bit 10        | BUFITEN        | rw                            | 1: An interrupt is generated when TDE = 1 or RDNE = 1.       |
|               |                |                               | (Regardless of the state of DMAEN).                          |
|               |                |                               | Event interrupt enable                                       |
|               |                |                               | 0: Event interrupt is disable.                               |
|               |                |                               | 1: Event interrupt is enable.                                |
|               |                |                               | Interrupts are generated in the following conditions:        |
|               |                |                               | – STARTF = 1 (Master mode)                                   |
| Bit 9         | EVTITEN        | rw                            | – ADDRF = 1 (Master/slave mode)                              |
|               |                |                               | – ADDR10F = 1 (Master mode)                                  |
|               |                |                               | -STOPF = 1 (Slave mode)                                      |
|               |                |                               | – BTFF = 1, but no TDE or RDNE event                         |
|               |                |                               | - If BUFITEN = 1, TDE event is 1.                            |
|               |                |                               | - If BUFITEN = 1, RDNE event is 1.                           |
|               |                |                               | Error interrupt enable                                       |
|               |                |                               | 0: Error interrupt is disable.                               |
| Bit 8 ERRITEN |                | 1: Error interrupt is enable. |                                                              |
|               | ERRITEN        |                               | Interrupts are generated in the following conditions:        |
|               |                |                               | – BUSERR = 1                                                 |
|               |                |                               | - ARLOST = 1                                                 |
|               |                | -ACKFAIL = 1                  |                                                              |



|         |                   | -OVRUN = 1                                                    |
|---------|-------------------|---------------------------------------------------------------|
|         |                   | - PECERR = 1                                                  |
|         |                   | -TIMOUT = 1                                                   |
|         |                   | -SMBALERTF = 1                                                |
|         |                   | Peripheral clock frequency                                    |
|         |                   | Correct input clock frequency must be set to generate correct |
|         |                   | timings. The range allowed is between 2 and 100 MHz:          |
|         |                   | 00000000: Not allowed                                         |
| Bit 7:0 | CLKFREQ[7:0]      | 0000001: Not allowed                                          |
|         |                   | 00000010: 2 MHz                                               |
|         |                   |                                                               |
|         | 01100100: 100 MHz |                                                               |

### 14.4.3 Own Address Register 1 (I2C\_OADDR1)

Address offset: 0x08

| Bit       | Name      | Туре | Description                                                                                                                                          |
|-----------|-----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15    | ADDRMODE  | rw   | Addressing mode (Slave mode)<br>0: 7-bit slave address (10-bit address not acknowledged)<br>1: 10-bit slave address (7-bit address not acknowledged) |
| Bit 14:10 | -         | -    | Reserved. Forced to be '0' by hardware.                                                                                                              |
| Bit 9:8   | ADDR[9:8] | rw   | Interface address<br>Not attended in 7-bit addressing mode.<br>The 9 ~ 8 bits of the address in 10-bit addressing mode.                              |
| Bit 7:1   | ADDR[7:1] | rw   | Interface address The 7 $\sim$ 1 bits of the address.                                                                                                |
| Bit 0     | ADDR0     | rw   | Interface address<br>Not attended in 7-bit addressing mode.<br>The 0 bit of the address in 10-bit addressing mode.                                   |



### 14.4.4 Own Address Register 2 (I2C\_OADDR2)

Address offset: 0x0C

Reset value: 0x0000

| Bit      | Name       | Туре | Description                                                                                                                                                    |
|----------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:8 | -          | -    | Reserved. Forced to be '0' by hardware.                                                                                                                        |
| Bit 7:1  | ADDR2[7:1] | rw   | Interface address<br>The 7 $\sim$ 1 bits in the dual address mode.                                                                                             |
| Bit 0    | DUALEN     | rw   | Dual addressing mode enable<br>0: Only OADDR1 is recognized in 7-bit addressing mode.<br>1: Both OADDR1 and OADDR2 are recognized in 7-bit<br>addressing mode. |

# 14.4.5 Data Register (I2C\_DT)

#### Address offset: 0x10

| Bit 15:8       -       -       Reserved. Forced to be '0' by hardware.         Bit 15:8       -       8-bit data register         Used to store data received or to be transmitted to the bus.         Transmitter mode: Data transmission starts automatically         when a byte is written in the DT register. Once the         transmission starts (TDE = 1), I <sup>2</sup> C will maintain a continuous         transmit stream if the next data to be transmitted is written         to the DT register in time.         Receiver mode: Received byte is copied into the DT register         (RDNE = 1). A continuous transmit stream can be         maintained if the data register is read before the next data         byte is received (RDNE = 1). | Bit      | Name    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 7:0DT[7:0]rwUsed to store data received or to be transmitted to the bus.<br>Transmitter mode: Data transmission starts automatically<br>when a byte is written in the DT register. Once the<br>transmission starts (TDE = 1), I²C will maintain a continuous<br>transmit stream if the next data to be transmitted is written<br>to the DT register in time.<br>Receiver mode: Received byte is copied into the DT register<br>(RDNE = 1). A continuous transmit stream can be<br>maintained if the data register is read before the next data                                                                                                                                                                                                             | Bit 15:8 | -       | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Bit 7:0  | DT[7:0] | rw   | Used to store data received or to be transmitted to the bus.<br>Transmitter mode: Data transmission starts automatically<br>when a byte is written in the DT register. Once the<br>transmission starts (TDE = 1), I <sup>2</sup> C will maintain a continuous<br>transmit stream if the next data to be transmitted is written<br>to the DT register in time.<br>Receiver mode: Received byte is copied into the DT register<br>(RDNE = 1). A continuous transmit stream can be |



|  | Note 1: In slave mode, the address is not copied into the        |
|--|------------------------------------------------------------------|
|  | data register, DT.                                               |
|  | Note 2: Write collision is not managed by hardware (DT can       |
|  | still be written if $TDE = 0$ ).                                 |
|  | Note 3: If an ARLOST event occurs on ACK pulse, the              |
|  | received byte is not copied into the data register, so it cannot |
|  | be read.                                                         |

### 14.4.6 Status Register 1 (I2C\_STS1)

Address offset: 0x14

| Bit    | Name      | Туре                                                 | Description                                                  |
|--------|-----------|------------------------------------------------------|--------------------------------------------------------------|
|        |           |                                                      | SMBus alert In SMBus host mode:                              |
|        |           |                                                      | 0: No SMBus alert                                            |
|        |           |                                                      | 1: SMBALERTF event occurs on the pin. In SMBus slave         |
|        |           |                                                      | mode:                                                        |
| Bit 15 | SMBALERTF | rc_w0                                                | 0: No SMBAlert response address header.                      |
|        |           |                                                      | 1: SMBAlert response address header to SMBAlert LOW          |
|        |           |                                                      | received.                                                    |
|        |           |                                                      | – This bit is cleared by software, or by hardware when PEN = |
|        |           |                                                      | 0.                                                           |
|        |           |                                                      | Timeout or Tlow error                                        |
|        |           |                                                      | 0: No timeout error                                          |
|        |           |                                                      | 1: SCL remains LOW for 25 ms (Timeout), or Master            |
|        |           |                                                      | cumulative clock low extend time is more than 10 ms (Tlow:   |
| Bit 14 | TIMOUT rc | rc_w0                                                | mext), or Slave cumulative clock low extend time is more     |
|        |           |                                                      | than 25 ms (Tlow: sext).                                     |
|        |           |                                                      | - When set in slave mode: Slave resets the communication,    |
|        |           |                                                      | and bus is released by hardware                              |
|        |           | - When set in master mode: Stop condition is sent by |                                                              |



|        |         |       | hardware.                                                                   |
|--------|---------|-------|-----------------------------------------------------------------------------|
|        |         |       |                                                                             |
|        |         |       | - Cleared by software, or by hardware when $PEN = 0$                        |
|        |         |       | Note: This function is available only in SMBus mode.                        |
| Bit 13 | -       | -     | Reserved. Forced to be '0' by hardware.                                     |
|        |         |       | PEC Error in reception                                                      |
|        |         |       | 0: No PEC error: Receiver returns ACK after PEC reception (if               |
| Bit 12 |         |       | ACKEN = 1).                                                                 |
| DICIZ  | PECERR  | rc_w0 | 1: PEC error occurs: Receiver returns NACK after PEC                        |
|        |         |       | reception (whatever the ACKEN value is).                                    |
|        |         |       | - This bit is cleared by software.                                          |
|        |         |       | Overrun/Underrun                                                            |
|        |         |       | 0: No overrun/underrun                                                      |
|        |         |       | 1: Overrun or underrun occurs.                                              |
|        |         |       | – Set by hardware in slave mode when NOCLKSTRETCH =                         |
|        |         |       | 1, and:                                                                     |
|        |         |       | <ul> <li>In reception mode, if a new byte is received (including</li> </ul> |
|        |         |       | ACK pulse), and the data register is not read yet, then                     |
| Bit 11 | OVRUN   | rc_w0 | the new received byte will be lost.                                         |
|        |         |       | – In transmission mode, if a new byte is to be sent, and                    |
|        |         |       | the data register is not written yet, then the same                         |
|        |         |       | byte will be sent twice.                                                    |
|        |         |       | - Cleared by software, or by hardware when PEN = 0.                         |
|        |         |       | Note: If the data register write access occurs very close to                |
|        |         |       | SCL rising edge, the sent data is unspecified, and a hold                   |
|        |         |       | timing error occurs.                                                        |
|        |         |       | Acknowledge failure                                                         |
|        |         |       | 0: No acknowledge failure                                                   |
| Bit 10 | ACKFAIL | w0    | 1: Acknowledge failure occurs.                                              |
|        |         |       | - Set by hardware when no acknowledge is returned.                          |
|        |         |       | - Cleared by software, or by hardware when PEN = 0.                         |
| Bit 9  | ARLOST  | w0    | Arbitration lost (master mode)                                              |



|           |        |    | 0: No arbitration lost is detected.                              |
|-----------|--------|----|------------------------------------------------------------------|
|           |        |    | 1: Arbitration lost is detected. Set by hardware when the        |
|           |        |    | interface loses the arbitration of the bus to another master     |
|           |        |    | - Cleared by software, or by hardware when $PEN = 0$ .           |
|           |        |    | After an ARLOST event, the $I^2C$ interface switches back to     |
|           |        |    |                                                                  |
|           |        |    | slave mode automatically $(M/SL = 0)$ .                          |
|           |        |    | Note: In SMBUS mode, the arbitration on the data in slave        |
|           |        |    | mode occurs only at the data phase, or the acknowledge           |
|           |        |    | transmission (not on the address acknowledge).                   |
|           |        |    | Bus error                                                        |
|           |        |    | 0: No misplaced Start or Stop condition                          |
|           |        |    | 1: Misplaced Start or Stop condition occurs.                     |
|           |        |    | – Set by hardware when the interface detects a misplaced         |
| Bit 8     | BUSERR | w0 | Start or Stop condition.                                         |
|           |        |    | - Cleared by software, or by hardware when PEN = 0.              |
|           |        |    | When BUSERR error occurs, this flag should be cleared by         |
|           |        |    | software in time to ensure that normal communication is          |
|           |        |    | resumed.                                                         |
|           |        |    | Data register empty (Transmitters)                               |
|           |        |    | 0: Data register is not empty.                                   |
|           |        |    | 1: Data register is empty.                                       |
|           |        |    | – Set when the data register is empty in transmission.           |
|           |        |    | This bit is not set at address transmission phase.               |
|           |        |    | – Cleared by software writing to the DT register, or             |
| Bit 7 TDE | TDE    | r  | automatically by hardware after a Start or a Stop                |
|           |        |    | condition occurs.                                                |
|           |        |    | This bit is not set either if a NACK is received, or if the next |
|           |        |    | byte to be transmitted is PECVAL (PECTRA = $1$ ).                |
|           |        |    | Note: The TDE bit is not cleared by writing the first data to    |
|           |        |    | be transmitted, or by writing data when BTFF is set, since in    |
|           |        |    | both cases the data register is still empty.                     |
| L         | 1      | I  |                                                                  |



|       |         |   | Data register not empty (Receivers)                         |
|-------|---------|---|-------------------------------------------------------------|
|       |         |   | 0: Data register is empty.                                  |
|       |         |   | 1: Data register is not empty.                              |
|       |         |   | – Set when the data register is not empty in receiver       |
| Bit 6 | RDNE    | - | mode. This bit is not set at address reception phase.       |
|       | RDNE    | r | – Cleared by software reading or writing the data register  |
|       |         |   | or by hardware when $PEN = 0$                               |
|       |         |   | RDNE is not set at ARLOST event.                            |
|       |         |   | Note: RDNE is not cleared by reading data when BTFF is set, |
|       |         |   | since the data register is still full.                      |
| Bit 5 |         | - | Reserved. Forced to be '0' by hardware.                     |
|       |         |   | Stop detection (Slave mode)                                 |
|       |         |   | 0: No Stop condition is detected.                           |
|       |         |   | 1: Stop condition is detected.                              |
|       |         |   | – Set by hardware when a Stop condition is detected on      |
| Bit 4 | STOPF   | r | the bus by the slave after an acknowledge (if ACKEN         |
|       |         |   | = 1).                                                       |
|       |         |   | – Cleared by a write to the CTRL1 register after the        |
|       |         |   | software reads the STS1 register, or by hardware            |
|       |         |   | when $PEN = 0$ .                                            |
|       |         |   | Note: The STOPF bit is not set after a NACK reception.      |
|       |         |   | 10-bit header sent (Master mode)                            |
|       |         |   | 0: No ADDR10F event occurs.                                 |
|       |         |   | 1: Master sends the first address byte.                     |
|       |         |   | – Set by hardware when the master sends the first byte in   |
| Bit 3 | ADDR10F | r | 10-bit addressing mode.                                     |
|       |         |   | – Cleared by a write to the CTRL1 register after the        |
|       |         |   | software reads the STS1 register, or by hardware            |
|       |         |   | when $PEN = 0$ .                                            |
|       |         |   | Note: The ADDR10F bit is not set after a NACK reception.    |



|             |       |   | Byte transfer finished                                        |
|-------------|-------|---|---------------------------------------------------------------|
|             |       |   | 0: Data byte transfer is not completed yet.                   |
|             |       |   | 1: Data byte transfer is completed.                           |
|             |       |   | When NOCLKSTRETCH = 0, set by hardware in the following       |
|             |       |   | conditions:                                                   |
|             |       |   | – In reception mode, when a new byte is received              |
|             |       |   | (including ACK pulse), and the data register is not           |
|             |       |   | read yet (RDNE = 1).                                          |
| Bit 2       | BTFF  | r | - In transmission mode, when a new byte is to be sent,        |
|             |       |   | and the data register is not written yet (TDE = 1).           |
|             |       |   | - Cleared by read or write access to the data register after  |
|             |       |   | software reads the STS1 register, or by hardware after        |
|             |       |   | a Start or Stop condition is sent in transmission.            |
|             |       |   | Note: The BTFF bit is not set after a NACK reception.         |
|             |       |   | The BTFF bit is not set if next byte to be transmitted is     |
|             |       |   | PECVAL (TRF = 1 in the I2C_STS2 register, and at the same     |
|             |       |   | time PECTRA = 1 in the I2C_CTRL1 register).                   |
|             |       |   | Address sent (Master mode)/matched (Slave mode)               |
|             |       |   | This bit is cleared by read access to the STS2 register after |
|             |       |   | software reads the STS1 register.                             |
|             |       |   | Address matched (Slave mode)                                  |
|             |       |   | 0: Address is mismatched or not received.                     |
|             |       |   | 1: Received address is matched.                               |
|             |       |   | – Set by hardware when the received slave address matches     |
| Bit 1 ADDRF | ADDRF | r | with the content of the OADDR register, or a general call,    |
|             |       |   | or a SMBus device default address, or SMBus host              |
|             |       |   | recognizes SMBus alert (If the corresponding                  |
|             |       |   | configuration is enabled).                                    |
|             |       |   | Address sent (Master mode)                                    |
|             |       |   | 0: Address transmission does not end.                         |
|             |       |   | 1: Address transmission ends.                                 |
|             |       |   | – Set after ACK of the 2nd byte is received in 10-bit         |



|       |        |          | addressing mode.                                              |
|-------|--------|----------|---------------------------------------------------------------|
|       |        |          | - Set after ACK of the byte is received in 7-bit addressing   |
|       |        |          | mode.                                                         |
|       |        |          | Note: ADDRF is not set after a NACK reception.                |
|       |        | STARTF r | Start bit (Master mode)                                       |
|       |        |          | 0: No Start condition                                         |
| Bit 0 | STARTE |          | 1: Start condition is generated.                              |
| START | START  |          | - Set when a Start condition is generated.                    |
|       |        |          | – Cleared by write access to the data register after software |
|       |        |          | reads the STS1 register.                                      |

### 14.4.7 Status Register 2 (I2C\_STS2)

Address offset: 0x18

| Bit      | Name         | Туре | Description                                                                                                                                                                                                                                                                                                   |
|----------|--------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:8 | PECVAL[7:0]  | r    | Packet error checking register<br>When PECEN = 1, PECVAL[7:0] stores internal PEC values. It<br>is cleared when PECEN is reset.                                                                                                                                                                               |
| Bit 7    | DUALF        | r    | <ul> <li>Dual flag (Slave mode)</li> <li>0: Received address matches with the content of OADDR1.</li> <li>1: Received address matches with the content of OADDR2.</li> <li>This bit is cleared by hardware when a Stop condition or a repeated Start condition is generated, or PEN = 0.</li> </ul>           |
| Bit 6    | SMBHOSTADDRF | r    | <ul> <li>SMBus host header (Slave mode)</li> <li>0: SMBus host address is not received.</li> <li>1: SMBus host address is received when SMBTYPE = 1 and</li> <li>ARPEN = 1.</li> <li>This bit is cleared by hardware when a Stop condition or a repeated Start condition is generated, or PEN = 0.</li> </ul> |



|       |              |   | SMBus device default address (Slave mode)                    |
|-------|--------------|---|--------------------------------------------------------------|
|       |              |   | 0: SMBus device default address is not received.             |
| Bit 5 | SMBDEFTADDRF | r | 1: SMBus device default address is received when ARPEN =     |
|       |              |   | 1.                                                           |
|       |              |   | - This bit is cleared by hardware when a Stop condition or a |
|       |              |   | repeated Start condition is generated, or $PEN = 0$ .        |
|       |              |   | General call address (Slave mode)                            |
|       |              |   | 0: General call address is not received.                     |
| Bit 4 | GCADDRF      | r | 1: General call address is received when $GCEN = 1$ .        |
|       |              |   | - This bit is cleared by hardware when a Stop condition or a |
|       |              |   | repeated Start condition is generated, or $PEN = 0$ .        |
| Bit 3 | -            | - | Reserved. Forced to be '0' by hardware.                      |
|       |              | r | Transmitter/receiver                                         |
|       |              |   | 0: Data is received.                                         |
|       |              |   | 1: Data is transmitted. At the end of the whole address      |
|       |              |   | transmission phase, this bit is set depending on the R/W bit |
| Bit 2 | TRF          |   | of the address byte.                                         |
|       |              |   | It is cleared by hardware after detection of Stop condition  |
|       |              |   | (STOPF = 1), repeated Start condition, bus arbitration lost  |
|       |              |   | (ARLOST = 1), or when PEN = 0.                               |
|       |              |   | Bus busy                                                     |
|       |              |   | 0: No data communication on the bus                          |
|       |              |   | 1: Data communication is ongoing on the bus.                 |
| Dit 1 |              |   | - Set by hardware on detection of SDA or SCL low             |
| Bit 1 | BUSYF        | r | - Cleared by hardware on detection of a Stop condition       |
|       |              |   | This bit indicates the ongoing communication on the bus.     |
|       |              |   | This information is still updated when the interface is      |
|       |              |   | disabled (PEN = 0).                                          |
|       | MCE          |   | Master/Slave                                                 |
| Bit 0 | MSF          | r | 0: Slave mode                                                |
|       | •            | • |                                                              |



|  | 1: Master mode                                          |
|--|---------------------------------------------------------|
|  | - Set by hardware when the interface is in master mode  |
|  | (STARTF = 1)                                            |
|  | - Cleared by hardware when a Stop condition is detected |
|  | on the bus, during arbitration lost (ARLOST = 1), or    |
|  | when $PEN = 0$ .                                        |

### 14.4.8 Clock Control Register (I2C\_CLKCTRL)

Address offset: 0x1C

Reset value: 0x0000

Note: 1. FPCLK1 must be a multiple of 10 MHz so that the 400 kHz fast mode clock can be correctly generated.

2. The CLKCTRL register can be configured only when  $I^2C$  is disabled (PEN = 0).

| Bit       | Name          | Туре | Description                                                                     |
|-----------|---------------|------|---------------------------------------------------------------------------------|
| Bit 15    | FIGNORE       |      | I <sup>2</sup> C master mode selection                                          |
| DICIS     | F/SMODE       | rw   | 0: Standard mode I <sup>2</sup> C                                               |
|           |               |      | 1: Fast mode I <sup>2</sup> C                                                   |
|           |               |      | Fast mode duty cycle                                                            |
| Bit 14    | FMDUTY        | rw   | 0: In fast mode: Tlow/Thigh = 2                                                 |
|           |               |      | 1: In fast mode: Tlow/Thigh = $16/9$ (Please refer to                           |
|           |               |      | CLKCTRL).                                                                       |
| Bit 13:12 | -             | -    | Reserved. Forced to be '0' by hardware.                                         |
|           |               |      | Clock control register in Fast/Standard mode (Master mode)                      |
|           |               |      | The divider ratio sets the SCL clock in master mode. In slave                   |
|           | CLKCTRL[11:0] |      | mode, it does not need to be configured, or is the same as                      |
| Bit 11:0  |               | rw   | the one in master mode according to the equation. In $\mathrm{I}^{2}\mathrm{C}$ |
|           |               |      | standard mode or SMBus mode:                                                    |
|           |               |      | Thigh = CLKCTRL × TPCLK1 Tlow = CLKCTRL × TPCLK1                                |
|           |               |      | In I <sup>2</sup> C fast mode:                                                  |



| If FMDUTY = 0:                                                   |
|------------------------------------------------------------------|
| Thigh = CLKCTRL × TPCLK1                                         |
| The = $2 \times CLKCTRL \times TPCLK1$                           |
| If FMDUTY = 1: (Up to 400 kHz)                                   |
| Thigh = $9 \times CLKCTRL \times TPCLK1$                         |
| The = $16 \times CLKCTRL \times TPCLK1$                          |
| For example: In standard mode, to generate SCL frequency         |
| of 100 kHz:                                                      |
| If CLKFREQ= 08, TPCLK1 = 125 ns, then CLKCTRLshouldbe            |
| written $0x28 (40 \times 125 \text{ ns} = 5000 \text{ ns}).$     |
| Note:                                                            |
| 1. The minimum value allowed is 0x04. In FAST DUTY mode,         |
| the minimum value allowed is 0x01.                               |
| 2. Thigh = $tr(SCL) + tw(SCLH)$ . Please refer to the data sheet |
| for detailed parameter definitions.                              |
| 3. Tlow = $tf(SCL) + tw(SCLL)$ . Please refer to the data sheet  |
| for detailed parameter definitions.                              |
| 4. These delays are without filter.                              |
| 5. The CLKCTRL register can be configured only when $I^2C$ is    |
| disabled (PEN = $0$ ).                                           |
| 6. fCK must be a multiple of 10 MHz so that the 400 kHz fast     |
| mode clock can be correctly generated.                           |

### 14.4.9 TMRISE Register (I2C\_TMRISE)

Address offset: 0x20

| Bit      | Name        | Туре | Description                                           |  |
|----------|-------------|------|-------------------------------------------------------|--|
| Bit 15:6 | -           | -    | Reserved. Forced to be '0' by hardware.               |  |
| Bit 5:0  | TMRISE[5:0] | rw   | Maximum rise time in Fast/Standard mode (Master mode) |  |
|          |             |      | These bits must be programmed as the maximum SCL rise |  |



|  | time given in the I <sup>2</sup> C bus specification, incremented by 1. |
|--|-------------------------------------------------------------------------|
|  | For instance: In standard mode, the maximum SCL rise time               |
|  | allowed is 1000 ns. If, in the I2C_CTRL2 register, the value of         |
|  | CLKFREQ[7:0] bits is equal to $0x08$ , and TPCLK1 = 125 ns,             |
|  | then the TRISE[5:0] bits must be programmed with 09h                    |
|  | (1000  ns/125  ns = 8+1). The filter value can also be added            |
|  | to TMRISE[5:0].                                                         |
|  | If the result is not an integer, TMRISE[5:0] must be                    |
|  | programmed with the integer part to ensure the tHIGH                    |
|  | parameter.                                                              |
|  | Note: TMRISE[5:0] must be configured only when I <sup>2</sup> C is      |
|  | disabled (PEN = 0).                                                     |



# 15 Universal Synchronous/Asynchronous Receiver/Transmitter (USART)

# **15.1 USART Introduction**

The universal synchronous asynchronous receiver transmitter (USART) offers a flexible means to realize full-duplex data exchange with external devices which require industry standard NRZ asynchronous serial data format. With a fractional baud rate generator, the USART offers a very wide range of baud rates.

It supports synchronous one-way communication and half-duplex single-wire communication. It also supports the LIN (local interconnection network), Smartcard Protocol, IrDA (infrared data association) SIR ENDEC specifications, and CTS/RTS (Clear To Send/Request To Send) hardware flow operation. It also allows multi-processor communication.

High speed data communication is possible by using the DMA with multi-buffer configuration.

## **15.2 USART Main Features**

- Full duplex, asynchronous communication
- Half duplex, single wire communication
- NRZ standard format (Mark/Space)
- Programmable baud rate generator
  - A common programmable transmit and receive baud rate up to 6.25 Mbit/s
- Programmable data word length (8 bits or 9 bits)
- Configurable stop bits Support 1 or 2 stop bits
- LIN master with break generation capability and LIN slave with break detection capability

When USART is hardware configured as LIN, 13-bit break generation and 10-bit/11-bit break detection

- Transmitter clock output for synchronous transmission
- IrDA SIR Encoder Decoder
  - Support 3-bit/16-bit duration in normal mode
- Asynchronous Smartcard protocol defined in ISO7816-3 Standard



Hangzhou Vango Technologies, Inc.

- Support 0.5 or 1.5 stop bits in Smartcard mode
- Configurable DMA multi-buffer communication
  - Buffering of received/transmitted data with DMA
- Separate enable bits for transmitter and receiver
- Detection flag
  - Receive buffer full
  - Transmit buffer empty
  - End of transition flag
- Parity control
  - Transmit parity bit
  - Parity check of received data
- Four error detection flags
  - Overrun error
  - Noise error
  - Framing error
  - Parity error
- 10 interrupt sources with flags
  - CTSF changes
  - LIN break detection
  - Transmit data register empty
  - Transmission completed
  - Receive data register full
  - Idle line detected
  - Overrun error
  - Framing error
  - Noise error
  - Parity error
- Multiprocessor communication If address does not match, enter mute mode.



- Wake up from mute mode (by idle line detection or address detection)
- Two ways to wake up receiver: Address bit (MSB, the 9th bit), idle line

## **15.3 USART Function Overview**

The interface is connected to other devices through three pins (See Figure 15-1). Any USART bidirectional communication requires at least two pins: receive data input (Rx) and transmit data output(Tx):

Rx: Serial data input uses oversampling techniques for data recovery by discriminating between data and noise.

Tx: Serial data output. When the transmitter is disabled, the output pin returns to its I/O port configuration. When the transmitter is enabled and does not transmit data, the Tx pin is at high level. In single-wire and Smartcard modes, this I/O port is used to transmit and receive the data at the same time.

- An idle line before transmission or reception
- A start bit
- A data word (8 bits or 9 bits), the least significant bit first
- 0.5, 1, 1.5, 2 stop bits, indicating the end of frame
- Use a fractional baud rate generator —— With 12-bit integer and 4-bit decimal
- A status register (USART\_STS)
- Data register (USART\_DT)
- A baud rate register (USART\_BAUDR) , 12-bit integer and 4-bit decimal
- A guard time register (GTVAL) in Smartcard mode

Please refer to <u>Section 15.6</u> for the detailed descriptions of each bit in the registers mentioned above. In synchronous mode, the following pins are required:

• CK: Transmitter clock output. This pin output is used for synchronous transmission clock (There is no clock pulses on the start bit and stop bit, and software can optionally send a clock pulse on the last data bit). Data can be received synchronously on Rx. This can be used to control peripherals that have shift registers (e.g. LCD drivers). The clock phase and polarity are software programmable. In Smartcard mode, CK can provide the clock for the Smartcard.

The following pins are required in hardware flow control mode:



• CTS: Cleared after reception. If it is low level, the next data transmission will occur after the current transmission ends. If it is high level, the next data transmission will be stopped by the end of current data transmission.

• RTS: Send requests. If it is low level, the USART is ready to receive a data.

#### Figure 15-1 USART Block Diagram





### **15.3.1 USART Feature Description**

Word length may be selected as 8 bits or 9 bits by programming the LEN bit in the USART\_CTRL1 register (See Figure 15-2). The Tx pin is at low state during the start bit. It is at high state during the stop bit.

Idle frame: A complete data frame of all '1', also including the stop bits of data. For example: If LEN = 0, idle frame consists of ten '1'; if LEN = 1, then idle frame consists of eleven '1'.

Break frame: Receiving all '0' for a frame period (including the stop bit period, which is also '0'). At the end of the break frame, the transmitter inserts either 1 or 2 stop bits ('1') to acknowledge the start bit.

Transmission and reception are driven by a common baud rate generator, the clock for each is generated when the enable bits of the transmitter and receiver are set respectively.

Figure 15-2 Word Length Programming



| 9-bit word length (The LEN bit is set), 1 stop bit Next data frame                                    |                                         |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------|-----------------------------------------|--|--|--|--|--|--|
| Possible<br>Data frame<br>Start<br>bit Bit 0 Bit 1 Bit 2 Bit 3 Bit 4 Bit 5 Bit 6 Bit 7 Bit 8<br>Clock | Stop bit                                |  |  |  |  |  |  |
| Idle frame                                                                                            | Start<br>bit<br>Stop                    |  |  |  |  |  |  |
| Break frame ** The LBCP bit control                                                                   | bit |  |  |  |  |  |  |
| 8-bit word length (The LEN bit is not set), 1 stop bit                                                |                                         |  |  |  |  |  |  |
| parity bit                                                                                            | Next<br>start<br>bit                    |  |  |  |  |  |  |
| Idle frame                                                                                            | Start<br>bit<br>Start<br>bit<br>bit     |  |  |  |  |  |  |
| Break frame<br>** The LBCP bit controls the clock pulse of the last data                              |                                         |  |  |  |  |  |  |

Note: In this chapter, if it is not specified, "set" means that a register is set as '1', while "reset" and "clear" means that a register is set as '0'. Hardware or programs can set or reset a register. Please refer to the detailed descriptions in this chapter.

### 15.3.2 Transmitter

The transmitter can send either 8-bit or 9-bit data words depending on the status of the LEN bit. When the transmit enable bit (TEN) is set, the data in the transmit shift register is outputted on the Tx pin; the corresponding clock pulses are outputted on the CK pin through configuration.



#### 15.3.2.1 Character Transmission

During a USART transmission, shift out the least significant bit of data first on the Tx pin. In this mode, the USART\_DT register includes a buffer between the internal bus and the transmit shift register (See Figure 15-1).

Every character is preceded by a low level start bit. The number of the stop bits followed is configurable. The USART supports several stop bit configurations: 0.5, 1, 1.5, and 2 stop bits.

*Note: 1. The TEN bit cannot be reset during data transmission, or the data on the Tx pin* will be corrupted as the baud rate counters stop counting. The current data being transmitted will be lost. *2. After the TEN bit is enabled, the USART will automatically send an idle frame.* 

#### 15.3.2.2 Configurable Stop Bit

The number of stop bits transmitted by each character can be programmed by the bits 13 and 12 in the control register 2 (USART\_CTRL2).

1.1 stop bit: Default value

2. 2 stop bits: Used in regular USART mode, single-wire mode, and modem mode

3. 0.5 stop bit: Used when receiving data in Smartcard mode

4. 1.5 stop bits: Used when transmitting and receiving data in Smartcard mode. An idle frame includes the stop bits.

A break frame is 10-bit low level followed by the configured number of stop bits (when LEN = 0), or 11bit low level followed by the configured number of stop bits (when LEN = 1). It is not possible to transmit longer break frames (length greater than 10 bits or 11 bits).

Figure 15-3 Stop Bits Configuration





Configuration procedure:

- 1. Enable the USART by writing 1 into the UEN bit in the USART\_CTRL1 register.
- 2. Program the LEN bit in USART\_CTRL1 to define the word length.
- 3. Program the STOPB bit in USART\_CTRL2 to define stop bit.

4. If multi-buffer communication is adopted, program the DMA enable bit (DMATEN) in USART\_CTRL3. The DMA register is configured according to the description of multi-buffer communication.

5. Program the USART\_BAUDR register to define baud rate.

6. Program the TEN bit in USART\_CTRL1 (that is, write 1 to the TEN bit), and the USART will automatically send an idle frame as the first data transmission.

7. Write the data to be sent in the USART\_DT register (which clears the TDE bit). Repeat this step to each data to be transmitted in single buffer cases.



8. After writing the last data into the USART\_DT register, wait until TRAC = 1. This indicates the end of the last frame transmission. When the USART needs to be disabled or before entering Halt mode, the end of transmission should be confirmed to a avoid corrupting the lasttransmission.

#### **15.3.2.3 Single Byte Communication**

The TDE bit is always cleared by a write to the data register.

The TDE bit is set by hardware (that is, the USART IP core), and this indicates:

• The data is moved from the TDR register (Transmitter Data Register) to the shift register, and the data transmission starts.

- The TDR register is empty.
- The next data can be written in the USART\_DT register without overwriting the previous data.

This flag generates an interrupt if the TDEIEN bit is set. If the USART is transmitting data at this time, a write access to the USART\_DT register stores the data in the TDR register, and the data is copied to the shift register at the end of the current transmission.

If the USART is not transmitting, a write access to the USART\_DT register places the data directly in the shift register, the data transmission starts, and the TDE bit is immediately set (that is, written '1').

If a frame transmission is completed (after the stop bit), and the TDE bit is set, the TRAC bit goes high. An interrupt is generated if the TRACIEN bit is set in the USART\_CTRL1 register.

After writing the last data into the USART\_DT register, it is mandatory to wait for TRAC = 1 before disabling the USART or making the microcontroller enter low-power mode (See Figure 15-4).

The TRAC bit is cleared by the following software sequence:

5. A read to the USART\_STS register

6. A write to the USART\_DT register

*Note: The TRAC bit can also be cleared by writing a '0' with software. This clearing* sequence is recommended only in multi-buffer communication mode.

Figure 15-4 TRAC/TDE Behavior during Transmission





### 15.3.2.4 Break Frame

Setting the SBRK bit transmits a break frame. The length of break frame depends on the LEN bit (See Figure 15-2). If the SBRK = 1, a break frame is sent on the Tx line after completing the current data transmission. The SBRK bit is reset by hardware when the break character transmission is completed (during the stop bit of the break frame). The USART inserts a logic '1' at the end of the last break frame to guarantee the recognition of the start bit of the next frame.

Note: If the software resets the SBRK bit before the break frame transmission, the break frame will not be transmitted. For two consecutive breaks, the SBRK bit should be set after the stop bit of the previous break.

#### 15.3.2.5 Idle Character

Setting the TEN bit drives the USART to send an idle frame before the first data frame.

### 15.3.3 Receiver

The USART can receive data words of either 8 bits or 9 bits depending on the LEN bit in the USART\_CTRL1 register.

### 15.3.3.1 Start Bit Detection

In the USART, the start bit is detected when a specific sequence of samples is recognized. This sequence



is: 1110X0X0X0000.

#### Figure 15-5 Start Bit Detection



Note: If the sequence is not complete, the receiver aborts the start bit detection and

returns to idle state (no flag is set), where it waits for a falling edge.

1. The start bit is confirmed if the sampling on the bits 3, 5, and 7, as well as the bits 8, 9, and 10 are at 0 (that is, six '0'). The NERR bit, noise flag, is not set.

2. The start bit is confirmed if there are two bits at '0' in the sampling on the bits 3, 5, and 7, and at the same time, two bits at '0' in the sampling on the bits 8, 9, and 10. However, the NERR bit, noise flag, will be set.

3. The start bit is confirmed if there are two bits at '0' in the sampling on the bits 3, 5, and 7, and at the same time, three bits at '0' in the sampling on the bits 8, 9, and 10. However, the NERR bit, noise flag, will be set.

4. The start bit is confirmed if there are three bits at '0' in the sampling on the bits 3, 5, and 7, and at the same time, two bits at '0' in the sampling on the bits 8, 9, and 10. However, the NERR bit, noise flag, will be set.



5. If the sampling values of the bits 3, 5, 7, 8, 9, and 10 do not meet the above four requirements, then the USART receiver considers that no correct start bits are received, and it will abort the start bit detection and return to idle state waiting for a falling edge.

#### 15.3.3.2 Character Reception

During a USART transmission, the least significant bits of data are shifted in first from the Rx pin. In this mode, the USART\_DT register includes a buffer between the internal APB bus and the receive shift register.

Configuration procedure:

1. Enable the USART by writing 1 to the UEN bit in the USART\_CTRL1 register.

2. Program the LEN bit in the USART\_CTRL1 to define the word length.

3. Program the STOPB bit in the USART\_CTRL2 to define stop bit.

4. If multi-buffer communication is adopted, program the DMA enable bit (DMAREN) in USART\_CTRL3. The DMA register is configured according to the description of multi-buffer communication.

5. Program the USART\_BAUDR register to define baud rate.

6. Program the REN bit in USART\_CTRL1 (that is, write 1 to the REN bit), and make it begin to find start bit.

When a character is received:

• The RDNE 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 (as well as its associated error flags).

• An interrupt is generated if the RDNEIEN bit is set.

• The error flags will be set if a framing error, noise, or an overrun error is detected during reception.

• In multi-buffer communication, RDNE is set after every byte is received, and it is cleared when the DMA reads the data register.

• In single buffer mode, the RDNE bit is cleared by software reading to the USART\_DT register. The RDNE flag can also be cleared by writing 0 to it. The RDNE bit must be cleared before the end of the next character reception to avoid an overrun error.

*Note: The REN bit should not be reset while receiving data. If the REN bit is cleared* during reception, the reception of the current byte will be lost.



#### 15.3.3.3 Break Frame

When a break frame is received, the USART handles it as a framing error.

Note: In LIN mode, when a break frame is received, it is handled as a break frame, and LBDF will be set.

#### 15.3.3.4 Idle Frame

When an idle frame is detected, it is handled as a normal data frame reception. However, an interrupt will be generated if the IDLEIEN bit is set.

#### 15.3.3.5 Overrun Error

An overrun error occurs if a received character is not read yet, which causes RDNE not reset in time, and another character is received. Data cannot be transferred from the shift register to the RDR register until the RDNE bit is cleared. The RDNE flag is set by hardware after every byte is received. An overrun error occurs if the RDNE flag is set when the next data is received, or the previous DMA request is not responded.

When an overrun error occurs:

- The ORERR bit is set.
- The RDR contentwillnotbe lost. The previous dataiss till available when reading the USART\_DT register.
- The shift register will be overwritten. After that, any data received will be lost.
- An interrupt is generated if either the RDNEIEN bit is set or both the ERRIEN and DMAREN bits are set.
- The ORERR bit is reset by reading the USART\_STS and then the USART\_DT registers in order.

*Note: When the ORERR bit is set, it indicates that at least 1 data is lost. There are two* possibilities:

• If RDNE = 1, then the last valid data is still stored in the receive register, RDR, and can be read.

• If RDNE = 0, it means that the last valid data is already read, and thus there is nothing to be read in the RDR. This case can occur when the last valid data is read in the RDR, and at the same time the new (and lost) data is received. It may also occur when the new data is received during the reading sequence (between the USART\_STS register read access and the USART\_DT read access).

For noise error, over-sampling techniques are used (except in synchronous mode) for data recovery by discriminating between valid incoming data and noise.







Table 15-1 Sampled Data from Noise Detection

| Sampled Value | NERR Status | Received Bit | 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         |

When noise is detected in a frame:

- The NERR flag is set at the rising edge of the RDNE bit.
- The invalid data is transferred from the shift register to the USART\_DT register.

• No noise interrupt is generated in single byte communication. However, RDNE generates an interrupt since the NERR flag bit and the RDNE flag bit are set at the same time. In multi-buffer communication, an interrupt will be generated if the ERRIEN bit in the USART\_CTRL3 register is set.

The NERR bit is reset by reading the USART\_STS register followed by the USART\_DT register in sequence.



#### 15.3.3.6 Framing Error

A framing error is detected when: The stop bit is not recognized on reception at the expected time because of data desynchronization or excessive noise.

When a framing error is detected:

- The FERR bit is set by hardware.
- The invalid data is transferred from the shift register to the USART\_DT register.

• No framing error interrupt is generated in single byte communication. However, this bit and the RDNE bit are set at the same time, and the latter will generate an interrupt. In multi-buffer communication, an interrupt will be generated if the ERRIEN bit is set in the USART\_CTRL3 register.

The FERR bit is reset by reading the USART\_STS register followed by the USART\_DT register in sequence.

#### 15.3.3.7 Configurable Stop Bits during Reception

The number of stop bits to be received can be configured through the control bits of the control register 2 (STOPB in USART\_CTRL2). It can be either 1 or 2 in normal mode, and 0.5 or 1.5 in Smartcard mode.

7. 0.5 stop bit (reception in Smartcard mode): No sampling is done for 0.5 stop bit. Therefore, framing error and break frame cannot be detected when 0.5 stop bit is selected.

8. 1 stop bit: Sampling for 1 stop bit is done on the 8th, 9th, and 10th samples.

9. 1.5 stop bits (Smartcard mode): When transmitting in Smartcard mode, the device must check that the data is correctly sent. Thus, the receiver block must be enabled (REN = 1 in the USART\_CTRL1 register), and sample the signals on the data line during stop bit transmission period. If parity error is detected, the Smartcard forces the data signal low when the transmitter samples the NACK signal, that is, within the corresponding time of stop bit on the bus, which indicates a framing error. Then, FERR is set at the end of the 1.5 stop bits. Sampling for 1.5 stop bits is done on the 16th, 17th, and 18th samples. For the Smartcard transmitter, the 1.5 stop bits can be decomposed into 2 parts: one 0.5 baud clock period during which nothing is done, followed by 1 normal stop bit period during which sampling occurs halfway through. For the Smartcard receiver, the 1.5 stop bits can also be decomposed into 2 parts: one 0.5 baud clock period during which parity check is done. If parity error occurs, the data signal is forced low in the following 1 period. If there is no parity error, release the data signal (which is at high level) in the following period. Please refer to Section 16.3.11 for more details.

10.2 stop bits: Sampling for 2 stop bits is done on the 8th, 9th and 10th samples of the first stop bit. If



a framing error is detected during the first stop bit, the framing error flag will be set. The second stop bit is not checked for framing error. The RDNE flag will be set at the end of the first stop bit.

## **15.3.4 Fractional Baud Rate Generation**

The baud rate for the receiver and transmitter are both set to the same value as programmed in the Integer and Decimal values of USARTDIV.

$$\frac{\text{TX}}{\text{RX}}baud = \frac{f_{CK}}{16 * \text{USARTDIV}}$$

Fck is the input clock to the peripheral (PCLK1 for USART2, 3, 4, 5, and PCLK2 for USART1) USARTDIV is an unsigned fixed point number that is coded in the USART\_BAUDR register.

*Note: The baud counters are updated with the new value of the baud registers after a* write to USART\_BAUDR. Therefore, the baud register value should not be changed during communication process.

### 15.3.4.1 How to Derive USARTDIV from USART\_BAUDR

### **Register Values**

Example 1:

```
If DIV_Integer = 27, DIV_Decimal = 12 (USART_BAUDR = 0x1BC), then DIV_Integer (USARTDIV) = 27
```

DIV\_Decimal (USARTDIV) = 12/16 = 0.75

Therefore, USARTDIV = 27.75 Example 2:

To program USARTDIV = 25.62, it leads to: DIV\_Decimal = 16\*0.62 = 9.92

The nearest real number:  $10 = 0x0A \text{ DIV}_{Integer} = \text{DIV}_{Integer} (25.620) = 25 = 0x19 \text{ Therefore},$ USART\_BAUDR = 0x19A

Example 3:

To program USARTDIV = 50.99, it leads to: DIV\_Decimal = 16\*0.99 = 15.84

The nearest real number:  $16 = 0x10 = DIV_Decimal[3:0]$  overflow = > carry must be added to the integer

 $DIV_Integer = DIV_Integer (0d50.990 + carry) = 51 = 0x33$ 

Therefore: USART\_BAUDR = 0x330, USARTDIV = 0d51.000



Hangzhou Vango Technologies, Inc.

|        | Baud  |         | f <sub>PCLK</sub> = 36 MHz            |         | f <sub>PCLK</sub> = 72 MHz |                                       |         |
|--------|-------|---------|---------------------------------------|---------|----------------------------|---------------------------------------|---------|
| Number | Kbps  | Actual  | Value programmed in the baud register | Error % | Actual                     | Value programmed in the baud register | Error % |
| 1      | 2.4   | 2.4     | 937.5                                 | 0%      | 2.4                        | 1875                                  | 0%      |
| 2      | 9.6   | 9.6     | 234.375                               | 0%      | 9.6                        | 468.75                                | 0%      |
| 3      | 19.2  | 19.2    | 117.1875                              | 0%      | 19.2                       | 234.375                               | 0%      |
| 4      | 57.6  | 57.6    | 39.0625                               | 0%      | 57.6                       | 78.125                                | 0%      |
| 5      | 115.2 | 115.384 | 19.5                                  | 0.15%   | 115.2                      | 39.0625                               | 0%      |
| 6      | 230.4 | 230.769 | 9.75                                  | 0.16%   | 230.769                    | 19.5                                  | 0.16%   |
| 7      | 460.8 | 461.538 | 4.875                                 | 0.16%   | 461.538                    | 9.75                                  | 0.16%   |
| 8      | 921.6 | 923.076 | 2.4375                                | 0.16%   | 923.076                    | 4.875                                 | 0.16%   |
| 9      | 2250  | 2250    | 1                                     | 0%      | 2250                       | 2                                     | 0%      |
| 10     | 4500  | NA      | NA                                    | NA      | 4500                       | 1                                     | 0%      |
| 11     | 6250  | NA      | NA                                    | NA      | NA                         | NA                                    | NA      |
| 12     | 7500  | NA      | NA                                    | NA      | NA                         | NA                                    | NA      |

### Table 15-2 Error Calculation for Programming Baud Rates

|        | Baud  | fPCLK = 1 | .00 MHz                               | fPCLK = 90 MHz |        |                                       |         |
|--------|-------|-----------|---------------------------------------|----------------|--------|---------------------------------------|---------|
| Number | Kbps  | Actual    | Value programmed in the baud register | Error %        | Actual | Value programmed in the baud register | Error % |
| 1      | 2.4   | 2.40004   | 2604.125                              | 0%             | 2.4    | 3125                                  | 0%      |
| 2      | 9.6   | 9.60061   | 651                                   | 0%             | 9.6    | 781.25                                | 0%      |
| 3      | 19.2  | 19.2012   | 325.5                                 | 0%             | 19.2   | 390.625                               | 0%      |
| 4      | 57.6  | 57.6037   | 108.5                                 | 0%             | 57.61  | 130.1875                              | 0%      |
| 5      | 115.2 | 115.207   | 54.25                                 | 0%             | 115.16 | 65.125                                | 0%      |
| 6      | 230.4 | 230.415   | 27.125                                | 0.01%          | 230.33 | 32.5625                               | 0%      |
| 7      | 460.8 | 460.829   | 13.5625                               | 0.01%          | 461.54 | 16.25                                 | 0.16%   |



| 8  | 921.6 | 925.926 | 6.75  | 0.47% | 923.08  | 8.125  | 0.16% |
|----|-------|---------|-------|-------|---------|--------|-------|
| 9  | 2250  | 2272.73 | 2.75  | 1%    | 2264.15 | 3.3125 | 0.63% |
| 10 | 4500  | 4545.45 | 1.375 | 1%    | 4444.44 | 1.6875 | 1.23% |
| 11 | 6250  | 6250    | 1     | 0%    | 6315.79 | 1.1875 | 1.05% |
| 12 | 7500  | NA      | NA    | NA    | 7500    | 1      | 0%    |

Note: 1. The lower the CPU clock frequency, the lower the error of a particular baud rate. The upper limit of the achievable baud rate can be obtained with this data.

2. Only USART1 is clocked with PCLK2 (Max. of 90 MHz). Other USARTs are clocked with PCLK1 (Max. of 90 MHz).

# **15.3.5 USART Receiver's Tolerance to Clock Deviation**

The USART asynchronous receiver can work normally only if the whole clock system deviation is within the range of the USART receiver tolerance. The factors that contribute to the deviation include:

• DTRA: Deviation caused by transmitter error (including the deviation of the transmitter's local oscillator)

- DQUANT: Error caused by the baud rate quantization of the receiver
- DREC: Deviation of the receiver's local oscillator

• DTCL: Deviation caused by the transmission line (generally due to the asymmetry between the lowto-high transition timing and the high-to-low transition timing of transceivers)

The following should be achieved:

DTRA + DQUANT + DREC + DTCL < USART receiver tolerance

For normal data reception, the USART receiver tolerance is equal to the maximum tolerated deviation. This depends on the following choices:

- 10-bit or 11-bit character length defined by the LEN bit in the USART\_CTRL1 register
- Whether to use fractional baud rate

Table 15-3 USART Receiver Tolerance When DIV\_Decimal = 0

| LEN bit | NF is considered an error | NF is not considered an error |
|---------|---------------------------|-------------------------------|
|---------|---------------------------|-------------------------------|



| 0 | 3.75 % | 4.375 % |
|---|--------|---------|
| 1 | 3.41 % | 3.97 %  |

Table 15-4 USART Receiver Tolerance When DIV\_Decimal! = 0

| LEN bit | NF is considered an error | NF is not considered an error |
|---------|---------------------------|-------------------------------|
| 0       | 3.33 %                    | 3.88 %                        |
| 1       | 3.03 %                    | 3.53 %                        |

*Note: The data specified in* Table 15-3 *and* Table 15-4 *may slightly differ in the special* cases when the received frames contain exactly 10-bit idle frames when LEN = 0 (11-bit when LEN = 1).

# **15.3.6 Multiprocessor Communication**

Multiprocessor communication can be achieved with the USART (connecting several USARTs in a network). For instance, one of the USARTs can be the master, and its Tx output is connected to the Rx input of other USARTs. Tx outputs of the USART slaves are logically ANDed together and connected to the Rx input of the master.

In multiprocessor configurations, usually only receivers to be addressed are enabled to receive data. This reduces redundant USART operation. Devices that are not addressed can be placed in mute mode.

In mute mode:

- None of the reception status bits can be set.
- All the receive interrupts are disabled.
- The RECMUTE bit in USART\_CTRL1 register is set to 1. RECMUTE can be controlled automatically by hardware or written by the software under certain conditions.

The USART can enter or exit mute mode with the following two methods, depending on the WUMODE bit in the USART\_CTRL1 register:

- If the WUMODE bit is reset: Perform idle line detection
- If the WUMODE bit is set: Perform address mark detection

## **15.3.6.1** Idle Line Detection (WUMODE = 0)

The USART enters mute mode when the RECMUTE bit is written to 1. It wakes up when an idle frame is



detected. Then, the RECMUTE bit is cleared by hardware, but the IDLEF bit is not set in the USART\_STS register. RECMUTE can also be written to 0 by software.

An example of mute mode behavior using idle line detection is shown in Figure 15-7.

Figure 15-7 Mute Mode Using Idle Line Detection



### **15.3.6.2** Address Mark Detection (WUMODE = 1)

In this mode, bytes are recognized as addresses if MSB is '1'; else, they are considered data. In an address byte, the address of the target receiver is put on the 4 LSB. This 4-bit address is compared by the receiver with its own address, which is programmed in the ADDR bits in the USART\_CTRL2 register.

If the parity function is disabled, MSB is USART\_DT[7] when LEN = 0, and MSB is USART\_DT[8] when LEN = 1; if the parity function is enabled, MSB is USART\_DT[6] when LEN = 0, and MSB is USART\_DT[7] when LEN = 1.

The USART enters mute mode when a received address character does not match its programmed address. In this case, the RECMUTE bit is set by hardware. The RDNE flag is not set for this address byte, and no interrupt nor DMA request is issued, as the USART is in mute mode.

The USART exits from mute mode when a received address character matches the programmed address. Then, the RECMUTE bit is cleared, and the subsequent bytes are received normally. The RDNE bit is set for the address character since the RECMUTE bit is cleared.

The RECMUTE bit can be written as 0 or 1 when the receiver buffer does not contain data (RDNE = 0 in the USART\_STS register). Otherwise, the write attempt is ignored. An example of mute mode behavior using address mark detection is shown in Figure 15-8.

Figure 15-8 Mute Mode Using Address Mark Detection





## 15.3.7 Parity Control

Parity control (generation of parity bit in transmission and parity checking in reception) can be enabled by setting the PCEN bit in the USART\_CTRL1 register. Depending on the frame length defined by the LEN bit, the possible USART frame formats are listed in Table 15-5.

| LEN bit | PCEN bit | USART Frame                                    |  |  |  |  |
|---------|----------|------------------------------------------------|--|--|--|--|
| 0       | 0        | Start bit   8-bit data   Stop bit              |  |  |  |  |
| 0       | 1        | Start bit   7-bit data   Parity bit   Stop bit |  |  |  |  |
| 1       | 0        | Start bit   9-bit data   Stop bit              |  |  |  |  |
| 1       | 1        | Start bit   8-bit data   Parity bit   Stop bit |  |  |  |  |

Table 15-5 Frame Format

Note: When an address mark wakes up the device, only the MSB bit of the data is taken into account for address matching, not the parity bit (MSB is the last one transmitted in data bits, and it is followed by the parity bit or the stop bit).

Even parity: The parity bit makes the 7 or 8 LSB bits in a frame and the number of '1' in the parity bit an even number. For example, there are four '1' in data = 00110101; if even parity is selected ( PSEL = 0 in USART\_CTRL1), the parity bit will be '0'.

Odd parity: The parity bit makes the 7 or 8 LSB bits in a frame and the number of '1' in the parity bit an odd number. For example, there are four '1' in data = 00110101; if odd parity is selected ( PSEL = 1 in USART\_CTRL1), the parity bit will be '1'.

Transmission mode: If the PCEN bit is set in USART\_ CTRL1, then the MSB bit of the data written



in the data register is transmitted after changed by the parity bit (even number of '1's if even parity is selected; odd number of '1's if odd parity is selected). If the parity check fails, the PERR flag is set in the USART\_STS register, and an interrupt is generated if PERRIEN is already set in the USART\_CTRL1 register.

# 15.3.8 LIN (Local Interconnection Network) Mode

The LIN mode is selected by setting the LINEN bit in the USART\_ CTRL2 register. In LIN mode, the following registers must be kept cleared:

- CLKEN in the USART\_CTRL2 register
- STOPB[1:0], SCMEN, HALFSEL, and IRDAEN in the USART\_CTRL3 register

### 15.3.8.1 LIN Transmission

The same procedure explained in Section 16.3.2 also applies to LIN master transmission, but for normal USART transmission, there are the following differences:

• Clear the LEN bit to configure 8-bit word length

• Set the LINEN bit to enter LIN mode. At the same time, setting the SBRK bit sends 13-bit '0' as a break frame. The break frame includes 13-bit '0' and 1-bit '1' to allow the detection on the next start bit.

### 15.3.8.2 LIN Reception

A break detection circuit is implemented when LIN mode is enabled. The detection is completely independent from the normal USART receiver. A break can be detected whenever it occurs, at idle state or during a frame (for example, a break is inserted while a frame is not completed).

When the receiver is enabled (REN = 1 in USART\_CTRL1), the circuit monitors the Rx input for a start signal. The method for detecting start bits is the same as searching break characters or data. After a start bit is detected, the circuit samples the following bits on the 8th, 9th, and 10th samples. If 10 (when LBDLEN = 0 in USART\_CTRL2) or 11 (when LBDLEN = 1 in USART\_CTRL2) consecutive bits are detected as '0', and are followed by a delimiter character (which is the rising edge of Rx), the LBDF flag will be set in USART\_STS. If the LBDIEN bit = 1, an interrupt is generated. Before validating the break, the delimiter should be checked, since it indicates that the Rx line returns to a high level.

If a '1' is sampled before the 10th or 11th sample, the break detection circuit cancels the current detection



and searches for a start bit again. If LIN mode is disabled (LINEN = 1), the receiver continues working as normal USART, without detecting the break. If LIN mode is enabled (LINEN = 1), once a framing error occurs (i.e. the stop bit detects at '0', which will be the case for any break frame), the receiver stops until the break detection circuit receives either a '1' (if the break word is not complete) or a delimiter character (if a complete break is detected). The behavior of the break detector state machine and the break flag is shown in Figure 15-9. Examples of break frames are shown in Figure 15-10.

Figure 15-9 Break Detection in LIN Mode (11-bit break length - The LBDLEN bit is set)

| RX line                     |            |           |       |        | Break | frame   |         |        |       |       |       |                     |          |          |
|-----------------------------|------------|-----------|-------|--------|-------|---------|---------|--------|-------|-------|-------|---------------------|----------|----------|
| Capture<br>strobe           |            |           |       |        |       |         |         |        |       |       |       |                     |          |          |
|                             |            |           |       |        |       |         |         |        |       |       |       |                     |          |          |
| Break state –<br>machine _  | Idle       | Bit 0     | Bit 1 | Bit 2  | Bit 3 | Bit 4   | Bit 5   | Bit 6  | Bit 7 | Bit 8 | Bit 9 | Bit 10              | Idle     |          |
| Sampled values              |            | 0         | 0     | 0      | 0     | 0       | 0       | 0      | 0     | 0     | 0     | 1                   |          |          |
| Case 2: Break               | u signal i | s iust le | ongen | ough = | > bre | ak det  | ected.  | LBDE   | et    |       |       |                     |          |          |
| RX line                     |            |           |       |        |       | frame   |         |        |       |       |       | Г                   |          |          |
| KA line                     |            |           |       |        | Dreak | . irame |         |        |       |       |       |                     |          |          |
| Capture<br>strobe           |            |           |       |        |       |         |         |        |       |       |       |                     |          |          |
|                             |            |           |       |        |       |         |         |        |       |       |       | imiter i<br>detecte |          |          |
| Break state<br>machine _    | Idle       | Bit 0     | Bit 1 | Bit 2  | Bit 3 | Bit 4   | Bit 5   | Bit 6  | Bit 7 | Bit 8 | Bit 9 | Bit 10              | Idle     |          |
| Sampled values              |            | 0         | 0     | 0      | 0     | 0       | 0       | 0      | 0     | 0     | 0     | 0                   |          |          |
|                             |            |           |       |        |       |         |         |        |       |       |       | 1                   |          |          |
| LBDF                        |            |           |       |        |       |         |         |        |       |       |       |                     |          |          |
| Case 3: Brea                | ak signal  | is long   | enou  | gh =>  | break | detect  | ed, LBI | DF set |       |       |       |                     |          |          |
| -<br>RX line                |            |           |       |        | Brea  | k frame | 2       |        |       |       |       |                     |          |          |
|                             |            |           |       |        |       |         | -       |        |       |       |       |                     |          |          |
| Capture<br>strobe           |            |           |       |        |       |         |         |        |       |       |       |                     |          |          |
| Break state 「               | Idle       | Bit 0     | Bit 1 | Bit 2  | Bit 3 | Bit 4   | Bit 5   | Bit 6  | Bit 7 | Bit 8 | Rit 0 | Bit 10              | Wait fo  | l Idle   |
| machine _<br>Sampled values | Ture       |           |       |        |       |         |         |        |       |       |       |                     | delimite | er lidie |
|                             |            | 0         | 0     | 0      | 0     | 0       | 0       | 0      | 0     | 0     | 0     | 0                   |          |          |
| LBDF                        |            |           |       |        |       |         |         |        |       |       |       |                     |          |          |

Figure 15-10 Break Detection and Framing Error Detection in LIN Mode



| In the following | examples, assume tha   | t LBDLEN = 1( break | length is 11 bits), LEN = 0 (8-bit data) |
|------------------|------------------------|---------------------|------------------------------------------|
| Case 1: Bre      | eak after idle         |                     |                                          |
| RX line          | Data 1 Idle            | Break               | Data 2 (0x55) Data 3 (Header)            |
|                  |                        | One data time       | One data time                            |
| RDNE/FERR        |                        |                     |                                          |
| LBDF             |                        |                     |                                          |
| Case 2: Br       | reak during data recep | tion                |                                          |
| RX line          | Data 1 Data 2          | Break               | Data 2 (0x55) Data 3 (Header)            |
|                  | One data               | time                | One data time                            |
| RDNE/FERR        |                        |                     |                                          |
| LBDF             |                        |                     |                                          |

### **15.3.9 USART Synchronous Mode**

The synchronous mode is selected by writing the CLKEN bit in the USART\_ CTRL2 register. In synchronous mode, the following control bits must be kept cleared:

- LINEN in the USART\_ CTRL2 register
- SCMEN, HALFSEL, and IRDAEN in the USART\_CTRL3 register

The USART allows users to control a bidirectional synchronous serial communications in master mode. The CK pin is the output of the USART transmitter clock. No clock pulses are sent to the CK pin during start bit and stop bit periods. Depending on the state of the LBCP bit in the USART\_CTRL2 register, clock pulses will or will not be generated during the last valid data bit. The CLKPOL bit in the USART\_CTRL2 register allows users to select the clock polarity, and the CLKPHA bit in the USART\_CTRL2 register allows users to select the phase of the external clock (See Figure 15-11, Figure 15-12, and Figure 15-13). During idle, the external CK clock is not activated before the actual data arrives and when break is being sent. In synchronous mode, the USART transmitter works exactly like in asynchronous mode. But as CK is synchronized with Tx (according to CLKPOL and CLKPHA), the data on Tx is synchronous with CK.

In synchronous mode, the USART receiver works in a different manner compared to the asynchronous mode. If REN = 1, the data is sampled on CK (rising or falling edge, depending on CLKPOL and CLKPHA), without any oversampling. However, a setup and a hold time must be taken into account (which depends



on the baud rate: 1/16-bit time).

*Note: 1. The CK pin works with the Tx pin. Thus, the clock is provided only if the* transmitter is enabled (TEN = 1) and a data is being transmitted (writing data to USART\_DT). This means that it is impossible to receive a synchronous data without transmitting data.

2. The LBCP, CLKPOL, and CLKPHA bits should be configured when both the transmitter and the receiver are disabled. These bits should not be changed while the transmitter or the receiver is enabled.

3. It is advised that TEN and REN should be set in the same instruction, to minimize the setup and the hold time of the receiver.

4. The USART supports master mode only: It cannot receive or send data with input clocks from other devices (CK is always an output).

Figure 15-11 Example of USART Synchronous Transmission



Figure 15-12 Example of USART Data Clock Timing (LEN = 0)





Figure 15-13 Example of USART Data Clock Timing (LEN = 1)



Figure 15-14 Rx Data Setup/Hold Time





*Note: CK function is different in Smartcard mode, please refer to the section of* Smartcard mode for more details.

# 15.3.10 Single-wire Half-duplex Communication

The single-wire half-duplex mode is selected by setting the HALFSEL bit in the USART\_ CTRL3 register. In this mode, the following bits must be kept cleared:

- LINEN and CLKEN in the USART\_CTRL2 register
- SCMEN and IRDAEN in the USART\_CTRL3 register

The USART can be configured to follow a single-wire half-duplex protocol. In single-wire half-duplex mode, the Tx and Rx pins are connected internally. The selection between half-duplex and full-duplex communication is done with the control bit, "HALFSEL" (in USART\_CTRL3).

When HALFSEL is '1'

• Rx is no longer used.

• Tx is always released when no data is transmitted. Thus, it acts as a standard I/O at idle state or in reception. It means that this I/O must be set as floating input (or output high open-drain) when it is not driven by the USART. In addition, the communication is similar to normal USART mode. Conflicts on the line are managed by the software (by the use of a centralized arbiter, for instance). In particular, the transmission is never blocked by hardware; that is, the USART cannot receive data when it is at transmission state. Namely, in half-duplex mode, transmission has higher priority over reception, and the conflicts between them should be handled by software. Transmission will continue as soon as data is written in the data register when the TEN bit is set.



### 15.3.11 Smartcard

The Smartcard mode is selected by setting the SCMEN bit in the USART\_CTRL3 register. In Smartcard mode, the following bits must be kept cleared:

- LINEN in the USART\_CTRL2 register
- HALFSEL and IRDAEN in the USART\_CTRL3 register

In addition, the CLKEN bit can be set to provide a clock to the Smartcard.

The Smartcard interface complies with ISO 7816-3 standard. It supports Smartcard asynchronous protocol. The USART should be configured as:

- 8 data bits plus parity bit: Where LEN = 1 and PCEN = 1 in the USART\_ CTRL1 register
- 1.5 stop bits when transmitting and receiving : Where STOPB = 11 in the USART\_ CTRL2 register

*Note: It is also possible to select 0.5 stop bit for receiving, but it is recommended that* 1.5 stop bits be used for both transmitting and receiving to avoid switching between the two configurations.

Figure 15-15 shows examples of signals on the data line with and without parity error.

#### Figure 15-15 ISO7816-3 Asynchronous Protocol



When connected to a Smartcard, the USART Tx output drives a bidirectional line which is also driven by the Smartcard. The Tx pin must be configured as open drain.

Smartcard is a single-wire half-duplex communication protocol.

Transmission of data from the transmit shift register is delayed by a minimum of 1/2 baud clock. In normal operation, a full transmit shift register will start shifting data on the next baud clock edge. In Smartcard mode, this transmission is further delayed by a guaranteed 1/2 baud clock.

• If a parity error is detected during reception of a frame programmed with a 0.5 or 1.5 stop bit period,



the transmit line is pulled low for a baud clock period after the completion of the receive frame (that is, the stop bit ends). This is to notify the Smartcard that the data transmitted to USART is correctly received. This NACK signal (pulling transmit line low for 1 baud clock) will cause a framing error on the transmitter side (configured with 1.5 stop bits). The application can re-send data according to the protocol. A parity error is "NACKed" by the receiver if the NACKEN control bit is set; otherwise, a NACK is not transmitted.

• If parity error is detected, FERR of the transmitter is set when the 1.5 stop bits ends. For the Smartcard transmitter, the 1.5 stop bits can be decomposed into 2 parts: one 0.5 data bit period during which nothing is done, followed by 1 stop bit of data period during which sampling occurs halfway through. For the Smartcard receiver, the 1.5 stop bits can also be decomposed into 2 parts: one 0.5 data bit period during which parity check is done. If parity error occurs, the data signal is forced low in the following 1 period. If there is no parity error, release the data signal (which is in high level) in the following period.

• The assertion of the TRAC flag can be delayed by programming the guard time register (GTVAL). In normal operation, TRAC is asserted when the transmit shift register is empty and no further transmit requests occur. In Smartcard mode, an empty transmit shift register triggers the guard time counter to count up to the programmed value in the guard time register (GTVAL). TRAC is forced low during this time (the time width of each bit in GTVAL). When the guard time counter reaches the programmed value, TC is asserted high (that is, set 1).

• The de-assertion of TRAC flag is not influenced by Smartcard mode.

• If a framing error is detected on the transmitter (a NACK signal from the receiver), the NACK signal will not be detected as a start bit by the receive block of the transmitter. According to the ISO protocol, the duration of the received NACK can be 1 or 2 baud clock periods.

• On the receiver side, if a parity error is detected and a NACK is transmitted, the receiver will not detect the NACK as a start bit.

*Note: 1. A break frame is not significant in Smartcard mode. A 00h data with a framing* error will be treated as data rather than a break.

2. No IDLE frame is transmitted when toggling the TEN bit. The IDLE frame is not defined by the ISO protocol.

Figure 15-16 details how the NACK signal is sampled by the USART. In this example, the USART transmits data and is configured with 1.5 stop bits. The receiver part of the USART is enabled in order to check the integrity of the data and the NACK signal.

Figure 15-16 Parity Error Detection Using 1.5 stop bits





The USART can provide a clock to the Smartcard through the CK output. In Smartcard mode, CK is not directly associated to the communication, but simply uses the internal peripheral input clock through a 5-bit prescaler to drive the clock of Smartcard. The division ratio is configured in the prescaler register, GTVAL. CK frequency can be programmed from  $f_{ck}/2$  to  $f_{ck}/62$ , where  $f_{ck}$  is the peripheral input clock.

## 15.3.12 IrDA SIR ENDEC Block

The IrDA mode is selected by setting the IRDAEN bit in the USART\_CTRL3 register. In IrDA mode, the following bits must be kept cleared:

- LINEN, STOPB, and CLKEN in the USART\_CTRL2 register
- SCMEN and HALFSEL in the USART\_CTRL3 register

The IrDA SIR physical layer specifies the use of a Return to Zero Inverted (RZI) modulation. This scheme uses an infrared light pulse to represent logic 0 (see Figure 15-17). The SIR transmit encoder modulates the Non Return to Zero (NRZ) transmit bit stream output from USART. The output pulse stream is transmitted to an external output driver and infrared LED. USART supports only bit rates up to 115.2 Kbps for the SIR ENDEC. In normal mode, the transmitted pulse width is specified as 3/16 of a bit period.



The SIR receive decoder demodulates the return-to-zero bit stream from the infrared detector and outputs the received NRZ serial bit stream to the USART. The decoder input is normally HIGH (marking state) at the idle state. The transmit encoder output has the opposite polarity to the decoder input. A start bit is detected when the decoder input is low.

• IrDA is a half-duplex communication protocol. If the transmitter is busy (i.e. the USART is sending data to the IrDA encoder), any data on the IrDA receive line is ignored by the IrDA decoder. If the receiver is busy (i.e. the USART is receiving decoded data from the USART), data on the Tx from the USART to IrDA is not encoded by IrDA. While receiving data, transmission should be avoided, or the data to be transmitted could be corrupted.

According to SIR transmission logic, a '0' is transmitted as a high pulse, and a '1' is transmitted as a '0'.
 The width of the pulse is specified as 3/16 of the selected bit period in normal mode (see Figure 15-18).

• The SIR receive logic interprets a high state as a '1' and low pulses as '0'.

• The transmit encoder output has the opposite polarity to the decoder input. The SIR output is at low state when idle.

• The SIR decoder converts the IrDA compatible receive signal into a bit stream for USART.

• The IrDA specification requires pulses greater than 1.41 us. The pulse width is programmable. The width of glitch detection logic filters on the receiver end should be less than 2 DIV periods (DIV is the prescaler value programmed in the IrDA low-power baud register, GTP). Pulse widths less than 1 DIV period are always rejected, but those of widths greater than one and less than two periods may be accepted or rejected, and those greater than 2 periods will be accepted as a pulse. The IrDA encoder/decoder doesn't work when DIV = 0.

- The receiver can communicate with a low-power transmitter.
- In IrDA mode, the STOPB bits in the USART\_ CTRL2 register must be configured to 1 stop bit.

### 15.3.12.1 IrDA low-power mode

For transmitters in low-power mode, the pulse width is not maintained at 3/16 of the bit period. Instead, the pulse width is 3 times of the low-power baud rate, which can be a minimum of 1.42 MHz. Generally this value is 1.8432 MHz (1.42 MHz < DIV < 2.12 MHz). A low-power mode programmable divisor divides the system clock to achieve this value. Receiver receiving in low-power mode is similar to receiving in normal mode. For glitch detection, the USART should discard pulses shorter than 1 DIV. A valid low signal is accepted only if its duration is greater than 2 periods of the IrDA low-power baud clock (DIV in



### USART\_GTP).

*Note: 1. A pulse width less than two and greater than one DIV period(s) may or may not be rejected.* 

2. The receiver set up time should be managed by software. The IrDA physical layer specification specifies a minimum of 10 ms delay between transmission and reception (IrDA is a half-duplex protocol).

Figure 15-17 IrDA SIR ENDEC Block Diagram



Figure 15-18 IrDA Data Modulation( 3/16) - Normal Mode



### **15.3.13 Continuous Communication Using DMA**

The USART is capable of continuing communication by using the DMA. The DMA requests for Rx buffer and Tx buffer are generated independently.

*Note:* If DMA is not available in the product, users should use the USART as explained in <u>Section</u> <u>15.3.2</u> or <u>Section 15.3.3</u>. In the USART\_STS register, users can clear the TDE/RDNE flags to achieve continuous communication.

### 15.3.13.1 Transmission Using DMA

DMA mode can be enabled for transmission by setting DMATEN bit in the USART\_CTRL3 register. Data is loaded from the specified SRAM area to the USART\_DT register by DMA when the TDE bit is set. To map



a DMA channel for USART transmission, use the following procedure (x denotes the channel number):

1. Configure the USART\_DT register address as the destination of DMA transfer in the DMA control register. Data will be sent to this address after each TDE event.

2. 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 this memory area after each TDE event.

3. Configure the total number of bytes to be transferred in the DMA control register.

- 4. Configure the channel priority in the DMA register
- 5. Configure DMA interrupt generation after half or full transfer as required by the application.
- 6. Activate the channel in the DMA register.

When the number of data transfers programmed in the DMA controller is reached, the DMA controller generates an interrupt on the DMA channel interrupt vector. In transmission mode, once the DMA finishes all the data to be transmitted, the TCIF flag is set in the DMA\_ISTS register by the DMA controller. The TRAC flag can be monitored to ensure that the USART communication is completed. This avoids corrupting the last transmission before disabling the USART or entering the Stop mode. The software must wait until TDE = 1, and then TRAC = 1.





### 15.3.13.2 Reception Using DMA

DMA mode can be enabled for reception by setting the DMAREN bit in USART\_CTRL3 register. Data is loaded from the USART\_ DT register to the specified SRAM area by DMA whenever a data byte is received



(Please refer to the DMA descriptions). To map a DMA channel for USART reception, use the following procedure (x denotes the channel number):

- 1. Configure the USART\_DT register address as the source of DMA transfer in the DMA control register. Data will be read from this address and sent to the memory after each RDNE event.
- 2. Configure the memory address as the destination of DMA transfer in the DMA control register. Data will be sent from the USART\_DT register to this memory area after each RDNE event.
- 3. Configure the total number of bytes to be transferred in the DMA control register.
- 4. Configure the channel priority in the DMA register
- 5. Configure DMA interrupt generation after half or full transfer as required by the application.
- 6. Activate the channel in the DMA register. When the number of data transfers programmed in the DMA Controller is reached, the DMA controller generates an interrupt on the DMA channel interrupt vector.



Figure 15-20 Reception Using DMA

# 15.3.13.3 Error Flag and Interrupt Generation in Multi-buffer Communication

In multi-buffer communication, if any error occurs during the communication, the error flag will be asserted after the current byte transmission. An interrupt will be generated if the interrupt enable bit is set. In single byte reception, there will be separate error flag interrupt enable bit for framing error, overrun



error, and noise flag asserted with RDNE; interrupts will be generated after the current byte transmission if these enable bits are set.

# **15.3.14 Hardware Flow Control**

It is possible to control the serial data flow between two devices by using the CTS input and the RTS output. Figure 15-21 shows how to connect two devices in this mode:

Figure 15-21 Hardware Flow Control between Two USART



RTS and CTS flow control can be enabled independently by setting the RTSEN and CTSEN bits in the USART\_CTRL3 register.

### 15.3.14.1 RTS Flow Control

If the RTS flow control is enabled (RTSEN = 1), then RTS is asserted (tied low) as long as the USART receiver is ready to receive new data. When the receive register is full (when each stop bit starts), RTS is set, indicating that the transmission is expected to stop at the end of the current frame. After RDNE is set, reading DT will clear RDNE, as well as RTS, indicating that receiver can receive the next data. Figure 15-22 shows an example of communication with RTS flow control enabled.

Figure 15-22 RTS Flow Control





### 15.3.14.2 CTS Flow Control

If the CTS flow control is enabled (CTSEN = 1), then the transmitter checks the CTS input before transmitting the next frame. If CTS is asserted (tied low), then the next data is transmitted (assuming that the data is ready to be transmitted, in other words, if TDE = 0); if CTS is deasserted (high) during a transmission, the transmitter stops after the current transmission is completed.

When CTSEN = 1, the CTSF status bit is automatically set by hardware as soon as the CTS input toggles. It indicates whether the receiver is ready for communication or not. An interrupt is generated if the CTSIEN bit in the USART\_CTRL3 register is set. Figure 15-23 shows an example of communication with CTS flow control enabled.



Figure 15-23 CTS Flow Control



# **15.4 USART Interrupt Request**

Table 15-6 USART Interrupt Request

| Interrupt Event                                                           | Event Flag            | Enable Bit    |  |  |
|---------------------------------------------------------------------------|-----------------------|---------------|--|--|
| Transmit data register empty                                              | TDE                   | TDEIEN        |  |  |
| CTS flag                                                                  | CTSF                  | CTSIEN        |  |  |
| Transmission completed                                                    | TRAC                  | TRACIEN       |  |  |
| Received data ready to be read                                            | RDNE                  | RDNEIEN       |  |  |
| Overrun error detected                                                    | ORERR                 | RDNEIEN       |  |  |
| Idle line detected                                                        | IDLEF                 | IDLEIEN       |  |  |
| Parity error                                                              | PERR                  | PERRIEN       |  |  |
| Break flag                                                                | LBDF                  | LBDIEN        |  |  |
| Noise flag, overrun error and framing error in multi-buffer communication | NERR or ORERR or FERR | ERRIEN (Note) |  |  |

Note: This flag bit is used only when DMA is used for data reception.

The USART interrupt events are connected to the same interrupt vector (See Figure 15-24). These events include:

• During transmission: transmission completed, CTS changes, and transmit data register empty

• During reception: idle line detection, overrun error, receive data register not empty, parity error, LIN break detection, noise flag (only in multi-buffer communication), and framing error (only in multi-buffer communication)

These events generate an independent interrupt if the corresponding enable control bit is set.

Figure 15-24 USART Interrupt Mapping Diagram





# **15.5 USART Mode Configuration**

| USART Mode                          | USART1 | USART2 | USART3 | UART4 | UART5 | UART6 | UART7 | UART8 |
|-------------------------------------|--------|--------|--------|-------|-------|-------|-------|-------|
| Asynchronous mode                   | х      | х      | х      | х     | х     | х     | х     | х     |
| Hardware flow control               | х      | Х      | х      | NA    | NA    | NA    | NA    | NA    |
| Multi-buffer<br>Communication (DMA) | x      | x      | х      | х     | NA    | х     | х     | x     |
| Multi-processor<br>communication    | х      | х      | х      | х     | х     | х     | х     | х     |
| Synchronous                         | х      | Х      | х      | NA    | NA    | х     | NA    | NA    |
| Smartcard                           | х      | Х      | х      | NA    | NA    | х     | NA    | NA    |
| Half-duplex (Single-<br>wire mode)  | х      | Х      | х      | Х     | х     | х     | х     | x     |
| IrDA                                | х      | Х      | х      | Х     | Х     | Х     | х     | х     |
| LIN                                 | х      | Х      | х      | Х     | х     | х     | х     | х     |

Table 15-7 USART Mode Configuration (Note)

Note: X = Applicable, NA = Not applicable



# **15.6 USART Registers**

# 15.6.1 Status Register (USART\_STS)

Address offset: 0x00

Reset value: 0x00C0

| Bit       | Name | Туре  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:10 | -    | -     | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 9     | CTSF | rc_w0 | CTS flag<br>If the CTSEN bit is set, this bit is set by hardware when the CTS<br>input toggles. It is cleared by software. An interrupt is generated<br>if CTSIEN is '1' in the USART_CTRL3 register.<br>0: No change on the CTS status line<br>1: A change occurs on the CTS status line.<br>Note: This bit is not available for UART4, UART5, USART6, UART7<br>and UART8.                                                                          |
| Bit 8     | LBDF | rc_w0 | LIN break detection flag<br>This bit is set by hardware when the LIN break is detected. It is<br>cleared by software (by writing 0). An interrupt is generated if<br>LBDIEN = 1 in the USART_USART_CTRL3 register.<br>0: LIN break is not detected.<br>1: LIN break is detected.<br>Note: If LBDIEN = 1, an interrupt is generated when LBDF is '1'.                                                                                                 |
| Bit 7     | TDE  | r     | Transmit data register empty<br>This bit is set by hardware when the content of the TDR register<br>is transferred into the shift register. An interrupt is generated if<br>the TDEIEN bit = 1 in the USART_CTRL1 register. It is cleared by<br>a write to the USART_DT register.<br>0: Data is not transferred to the shift register.<br>1: Data is transferred to the shift register.<br>Note: This bit is used during single buffer transmission. |



Hangzhou Vango Technologies, Inc.

|       |       |       | Transmission complete                                               |
|-------|-------|-------|---------------------------------------------------------------------|
|       |       |       | This bit is set by hardware if transmission of a frame containing   |
|       |       |       | data is completed and TDE = 1. An interrupt is generated if         |
|       |       |       | TRACIEN is '1' in the USART_CTRL1 register. It is cleared by        |
|       |       |       | software sequence (a read to the USART_STS register followed        |
| Bit 6 | TRAC  | rc_w0 | by a write to the USART_DT register). The TRAC bit can also be      |
|       |       |       | cleared by writing a '0'. This clearing sequence is recommended     |
|       |       |       | only for multi-buffer communication.                                |
|       |       |       | 0: Transmission is not completed.                                   |
|       |       |       | 1: Transmission is completed.                                       |
|       |       |       | Read data register not empty                                        |
|       |       |       | This bit is set by hardware when the content of the RDR shift       |
|       |       |       | register is transferred to the USART_DT register. An interrupt is   |
|       | RDNE  | rc_w0 | generated if RDNEIEN IS `1' in the USART_CTRL1 register. It is      |
| Bit 5 |       |       | cleared by a read to the USART_DT register. The RDNE flag can       |
|       |       |       | also be cleared by writing '0'. This clearing sequence is           |
|       |       |       | recommended only for multi-buffer communication.                    |
|       |       |       | 0: Data is not received.                                            |
|       |       |       | 1: Received data is ready to be read.                               |
|       |       |       | IDLE line detected                                                  |
|       |       |       | This bit is set by hardware when an idle line is detected. An       |
|       |       |       | interrupt is generated if the IDLEIEN bit is $1'$ in the            |
|       |       |       | USART_CTRL1 register. It is cleared by a software sequence (a       |
| Bit 4 | IDLEF |       | read to the USART_STS register followed by a read to the            |
|       |       |       | USART_DT register).                                                 |
|       |       |       | 0: No idle line is detected, nor is idle frame.                     |
|       |       |       | 1: Idle line is detected.                                           |
|       |       |       | Note: The IDLEF bit will not be set again until the RDNE bit is set |
|       |       |       | (i.e. a new idle line is detected).                                 |
|       |       |       | Overrun error                                                       |
| Bit 3 | ORERR | r     | This bit is set by hardware when the data currently being           |
|       |       |       | received in the shift register needs to be transferred into the RDR |



|       |      | 1 |                                                                    |
|-------|------|---|--------------------------------------------------------------------|
|       |      |   | register while RDNE = 1. An interrupt is generated if RDNEIEN =    |
|       |      |   | 1 in the USART_CTRL1 register. It is cleared by a software         |
|       |      |   | sequence (a read to the USART_STS register followed by a read      |
|       |      |   | to the USART_CTRL register).                                       |
|       |      |   | 0: No overrun error                                                |
|       |      |   | 1: Overrun error is detected.                                      |
|       |      |   | Note: When this bit is set, the RDR register content will not be   |
|       |      |   | lost, but the shift register will be overwritten. An interrupt is  |
|       |      |   | generated by ORERR flag if the ERRIEN bit is set in multi-buffer   |
|       |      |   | communication mode.                                                |
|       |      |   | Noise error flag                                                   |
|       |      |   | This bit is set by hardware when noise is detected on a received   |
|       |      |   | frame. It is cleared by a software sequence (a read to the         |
|       |      |   | USART_STS register followed by a read to the USART_DT              |
|       |      |   | register).                                                         |
| Bit 2 | NERR | r | 0: No noise is detected.                                           |
|       |      |   | 1: Noise is detected.                                              |
|       |      |   | Note: This bit does not generate interrupt as it appears with the  |
|       |      |   | RDNE bit which generates an interrupt when its flag is set by      |
|       |      |   | hardware. If the ERRIEN bit is set, an interrupt is generated when |
|       |      |   | the NERR flag is set in multi-buffer communication.                |
|       |      |   | Framing error                                                      |
|       |      |   | This bit is set by hardware when a de-synchronization, excessive   |
|       |      |   | noise, or a break character is detected. It is cleared by a        |
|       |      |   | software sequence (a read to the USART_STS register followed       |
|       |      |   | by a read to the USART_DT register).                               |
| Bit 1 | FERR | r | 0: No framing error is detected.                                   |
|       |      |   | 1: Framing error or break frame is detected.                       |
|       |      |   | Note: This bit does not generate interrupt as it appears with the  |
|       |      |   | RDNE bit which generates an interrupt when its flag is set by      |
|       |      |   | hardware. If the data currently being transferred causes both      |
|       |      |   | framing error and overrun error, the hardware will continue the    |
|       |      |   |                                                                    |



|       |      |   | data transmission and only set ORERR flag bit. If the ERRIEN bit is |
|-------|------|---|---------------------------------------------------------------------|
|       |      |   | set, an interrupt is generated when the FERR flag is set in multi-  |
|       |      |   | buffer communication.                                               |
|       |      |   | Parity error                                                        |
|       |      |   | This bit is set by hardware when parity error occurs in receiver    |
|       |      |   | mode. It is cleared by software sequence (a read to the             |
|       |      |   | USART_STS register followed by a read to the USART_DT register).    |
| Bit 0 | PERR | r | The software must wait for the RDNE flag to be set before clearing  |
|       |      |   | the PERR bit. An interrupt is generated if PERRIEN is `1' in the    |
|       |      |   | USART_ CTRL1 register.                                              |
|       |      |   | 0: No parity error                                                  |
|       |      |   | 1: Parity error                                                     |

# 15.6.2 Data Register (USART\_DT)

Address offset: 0x04

Reset value: 0x0000

| Bit      | Name         | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------|--------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:9 | -            | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 31:9 | -<br>DT[8:0] | rw   | Reserved. Forced to be '0' by hardware.<br>Data value<br>These bits contain the received or transmitted data. It is<br>composed of two registers, one for transmission (TDR) and one for<br>reception (RDR).This register provides both read and write<br>function. The TDR register provides the parallel interface between<br>the internal bus and the output shift register (Please refer to<br>Figure 15-1). The RDR register provides the parallel interface |
|          |              |      | between the input shift register and the internal bus.<br>When transmitting with the parity bit enabled (the PCEN bit is set<br>in the USART_ CTRL1 register), the value written in the MSB (bit<br>7 or bit 8, depending on the data length) will be replaced by the<br>parity bit. When receiving with the parity bit enabled, the value                                                                                                                        |



|  | read in the MSB bit is the received parity bit. |
|--|-------------------------------------------------|
|  |                                                 |

# 15.6.3 Baud Rate Register (USART\_BAUDR)

Address offset: 0x08

Reset value: 0x0000

| Bit       | Name              | Туре | Description                                                                        |
|-----------|-------------------|------|------------------------------------------------------------------------------------|
| Bit 31:18 | -                 | -    | Reserved. Forced to be '0' by hardware.                                            |
| Bit 15:4  | DIV_Integer[11:0] | rw   | Integer of USARTDIV<br>The 12 bits define the integer of USART Divider (USARTDIV). |
| Bit 3:0   | DIV_Decimal[3:0]  | rw   | Decimal of USARTDIV<br>The 4 bits define the decimal of USART Divider (USARTDIV).  |

*Note: If TE or RE is disabled respectively, the baud counter stops counting.* 

# 15.6.4 Control Register 1 (USART\_CTRL1)

Address offset: 0x0C

Reset value: 0x0000

Mango

| Bit       | Name | Туре | Description                                                                                                                                                                                                                                                                                         |
|-----------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:14 | -    | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                             |
| Bit 13    | UEN  | rw   | USART enable<br>When this bit is cleared, the USART prescalers and outputs are<br>stopped at the end of the current byte transfer in order to<br>reduce power consumption. This bit is set and cleared by<br>software.<br>0: USART prescaler and outputs are both disabled.<br>1: USART is enabled. |
| Bit 12    | LEN  | rw   | Word length<br>This bit defines the word length. It is set or cleared by software.<br>0: 1 start bit, 8 data bits, n stop bit(s)                                                                                                                                                                    |



| Bit 11 | WUMODE  | rw | <ul> <li>1: 1 start bit, 9 data bits, n stop bit(s)</li> <li>Note: This bit cannot be modified during a data transfer (both transmission and reception).</li> <li>Wakeup mode WAKE: Wakeup method</li> <li>This bit determines the way to wake up USART method. It is set or cleared by software.</li> <li>0: Wakeup by idle line</li> <li>1: Wakeup by address mark</li> </ul>                                                                                                                                                                               |
|--------|---------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 10 | PCEN    | rw | Parity control enable<br>This bit selects the hardware parity control (generation of parity<br>bit for transmission; detection of parity bit for reception). When<br>this bit is enabled, the computed parity is inserted at the MSB<br>position (the 9th bit if LEN = 1; the 8th bit if LEN = 0), and<br>parity is checked on the received data. This bit is set and<br>cleared by software.<br>Once it is set, parity control is active after the current byte<br>transfer is completed.<br>0: Parity control is disabled.<br>1: Parity control is enabled. |
| Bit 9  | PSEL    | rw | <ul> <li>Parity selection</li> <li>This bit selects the odd or even parity after the parity control is enabled. It is set and cleared by software. The parity selection is active after the current byte transfer is completed.</li> <li>0: Even parity</li> <li>1: Odd parity</li> </ul>                                                                                                                                                                                                                                                                     |
| Bit 8  | PERRIEN | rw | PERR interrupt enable This bit is set and cleared by software. 0:<br>Interrupt is disabled.<br>1: A USART interrupt is generated when PERR is '1' in the<br>USART_STS register.                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 7  | TDEIEN  | rw | TDE interrupt enable<br>This bit is set and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |



|       |         |    | <ul><li>0: Interrupt is disabled.</li><li>1: A USART interrupt is generated when TDE is '1' in the</li></ul> |
|-------|---------|----|--------------------------------------------------------------------------------------------------------------|
|       |         |    |                                                                                                              |
|       |         |    | USART_STS register.                                                                                          |
|       |         |    | TRAC interrupt enable                                                                                        |
|       |         |    | This bit is set or cleared by the software.                                                                  |
| Bit 6 | TRACIEN | rw | 0: No interrupt is allowed;                                                                                  |
|       |         |    | 1: When the TRAC in the USART_STS is' 1 ', a USART interrupt                                                 |
|       |         |    | is generated.                                                                                                |
|       |         |    | RDNE interrupt enable                                                                                        |
|       |         |    | This bit is set and cleared by software.                                                                     |
| Bit 5 | RDNEIEN | rw | 0: Interrupt is disabled.                                                                                    |
|       |         |    | 1: A USART interrupt is generated when RDNE or ORERR is `1' in the                                           |
|       |         |    | USART_STS register.                                                                                          |
|       |         |    | IDLE interrupt enable                                                                                        |
|       |         |    | This bit is set and cleared by software.                                                                     |
| Bit 4 | IDLEIEN | rw | 0: Interrupt is disabled.                                                                                    |
|       |         |    | 1: A USART interrupt is generated when IDLEF is `1' in the                                                   |
|       |         |    | USART_STS register.                                                                                          |
|       |         |    | Transmitter enable                                                                                           |
|       |         |    | This bit enables the transmitter. It is set and cleared by                                                   |
|       |         |    | software.                                                                                                    |
|       |         |    | 0: Transmitter is disabled.                                                                                  |
|       |         |    | 1: Transmitter is enabled.                                                                                   |
| Bit 3 | TEN     | rw | Note 1: During transmission, except in Smartcard mode, if                                                    |
|       |         |    | there is 0 pulse on the TEN bit (set $0'$ and then set $1'$ ), a                                             |
|       |         |    | preamble (idle line, or idle frame) will be sent after the current                                           |
|       |         |    | byte transfer is completed,.                                                                                 |
|       |         |    | Note 2: After TEN is set, there is a 1-bit time delay before the                                             |
|       |         |    | transmission actually starts.                                                                                |
| Bit 2 | REN     | rw | Receiver enable                                                                                              |
|       |         |    | zhou Vango Technologies, Inc. 570 / 782                                                                      |



Hangzhou Vango Technologies, Inc.

|       |         |    | This bit is set and cleared by software.                          |
|-------|---------|----|-------------------------------------------------------------------|
|       |         |    | 0: Receiver is disabled.                                          |
|       |         |    |                                                                   |
|       |         |    | 1: Receiver is enabled and begins searching for a start bit on Rx |
|       |         |    | pin.                                                              |
|       |         |    | Receiver wakeup                                                   |
|       |         |    | This bit determines if the USART is in mute mode or not. It is    |
|       |         |    | set and cleared by software. It is cleared by hardware when a     |
|       |         |    | wakeup sequence is recognized.                                    |
|       |         | rw | 0: Receiver is in active mode.                                    |
| Bit 1 | RECMUTE |    | 1: Receiver is in mute mode.                                      |
|       |         |    | Note 1: Before selecting mute mode (by setting the RECMUTE        |
|       |         |    | bit), the USART must first receive a data byte; otherwise, it     |
|       |         |    | cannot wake up by idle line detection in mute mode.               |
|       |         |    | Note 2: In address mark detection wakeup configuration            |
|       |         |    | (WUMODE bit = 1), the RECMUTE bit cannot be modified by           |
|       |         |    | software while the RDNE bit is set.                               |
|       |         | rw | Send break                                                        |
|       |         |    | This bit set is used to send break characters. It can be set and  |
|       |         |    | cleared by software. It should be set by software and be reset    |
| Bit 0 | SBRK    |    | by hardware during the stop bit of break.                         |
|       |         |    | 0: No break character is transmitted.                             |
|       |         |    | 1: Break character will be transmitted.                           |

# 15.6.5 Control Register 2 (USART\_CTRL2)

Address offset: 0x10

Reset value: 0x0000

| Bit       | Name  | Туре | Description                                                 |
|-----------|-------|------|-------------------------------------------------------------|
| Bit 31:15 | -     | -    | Reserved. Forced to be '0' by hardware.                     |
| Bit 14    | LINEN | rw   | LIN mode enable<br>This bit is set and cleared by software. |



|           |        | r  |                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|--------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |        |    | 0: LIN mode is disabled.                                                                                                                                                                                                                                                                                                                                                                               |
|           |        |    | 1: LIN mode is enabled.                                                                                                                                                                                                                                                                                                                                                                                |
|           |        |    | In LIN mode, the SBR bit in the USART_CTRL1 register can be                                                                                                                                                                                                                                                                                                                                            |
|           |        |    | used to send LIN synch breaks (13 low bits) and to detect LIN                                                                                                                                                                                                                                                                                                                                          |
|           |        |    | sync breaks.                                                                                                                                                                                                                                                                                                                                                                                           |
|           |        |    | STOP bits                                                                                                                                                                                                                                                                                                                                                                                              |
|           |        |    | These bits are used for programming the number of stop bits.                                                                                                                                                                                                                                                                                                                                           |
|           |        |    | 00: 1 stop bit                                                                                                                                                                                                                                                                                                                                                                                         |
| D1 40 40  | CTODD  |    | 01: 0.5 stop bit                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 13:12 | STOPB  | rw | 10: 2 stop bits                                                                                                                                                                                                                                                                                                                                                                                        |
|           |        |    | 11: 1.5 stop bits                                                                                                                                                                                                                                                                                                                                                                                      |
|           |        |    | Note: The 0.5 stop bit and 1.5 stop bits are not available for                                                                                                                                                                                                                                                                                                                                         |
|           |        |    | UART4, UART5, UART7 and UART8.                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 11    | CLKEN  | rw | Clock enable<br>This bit enables the CK pin.<br>0: CK pin is disabled.<br>1: CK pin is enabled.<br>Note: This bit is not available for UART4, UART5, UART7 and<br>UART8.                                                                                                                                                                                                                               |
| Bit 10    | CLKPOL | rw | Clock polarity<br>This bit selects the polarity of the clock output on the SLCK pin<br>in synchronous mode. It works in conjunction with the CLKPHA<br>bit to produce the desired clock/data sample relationship<br>0: Stay low on CK pin outside transmission window.<br>1: Stay high on CK pin outside transmission window.<br>Note: This bit is not available for UART4, UART5, UART7 and<br>UART8. |
| Bit 9     | CLKPHA | rw | Clock phase<br>This bit selects the phase of the clock output on the SLCK pin in<br>synchronous mode. It works in conjunction with the CLKPOL bit<br>to produce the desired clock/data sample relationship (Please                                                                                                                                                                                     |



| 1     | I      |    |                                                                     |
|-------|--------|----|---------------------------------------------------------------------|
|       |        |    | refer to Figure 15-12 and Figure 15-13).                            |
|       |        |    | 0: Data capture is done on the clock leading edge.                  |
|       |        |    | 1: Data capture is done on the clock trailing edge.                 |
|       |        |    | Note: This bit is not available for UART4, UART5, UART7 and         |
|       |        |    | UART8.                                                              |
|       |        |    | Last bit clock pulse                                                |
|       |        | rw | This bit selects whether the clock pulse of the last data bit       |
|       |        |    | transmitted (MSB) is outputted on the CK pin in synchronous         |
|       |        |    | mode.                                                               |
|       |        |    | 0: The clock pulse of the last data bit is not outputted to the CK  |
|       |        |    | pin.                                                                |
| Bit 8 | LBCP   |    | 1: The clock pulse of the last data bit is outputted to the CK pin. |
|       |        |    | Note 1: The last bit is the 8th or the 9th data bit transmitted     |
|       |        |    | (depending on the 8-bit or 9-bit format selected by the LEN bit     |
|       |        |    | in the USART_CTRL1 register.)                                       |
|       |        |    | Note 2: This bit is not available for UART4, UART5, UART7 and       |
|       |        |    | UART8.                                                              |
| Bit 7 | -      | -  | Reserved. Forced to be '0' by hardware.                             |
|       | LBDIEN | rw | LIN break detection interrupt enable                                |
|       |        |    | Break interrupt mask (using break delimiter to detect breaks)       |
| Bit 6 |        |    | 0: Interrupt is disabled.                                           |
|       |        |    | 1: An interrupt is generated when LBDF is '1' in the USART_STS      |
|       |        |    | register.                                                           |
|       |        |    | LIN break detection length                                          |
|       | LBDLEN | rw | This bit is for the selection between 11-bit and 10-bit break       |
| Bit 5 |        |    |                                                                     |
|       |        |    | detection.                                                          |
|       |        |    | 0: 10-bit break detection                                           |
|       |        |    | 1: 11-bit break detection                                           |
|       |        |    | Note: LBDLEN can be used in break detection length control in       |
|       |        |    | LIN mode and other modes, and the detection length is the           |
|       |        |    | same as LIN mode.                                                   |



| Bit 4   | -         | -  | Reserved. Forced to be '0' by hardware.                          |
|---------|-----------|----|------------------------------------------------------------------|
| Bit 3:0 | ADDR[3:0] | rw | USART node address in this device                                |
|         |           |    | This bit-field gives the address of the USART node. This is used |
|         |           |    | in mute mode in multi-processor communication, for waking up     |
|         |           |    | a USART device with address mark detection.                      |

Note: The three bits, CLKPOL, CLKPHA, and LBCP, cannot be modified after enabling transmission.

# 15.6.6 Control Register 3 (USART\_CTRL3)

Address offset: 0x14

Reset value: 0x0000

| Bit       | Name   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:11 | -      | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 10    | CTSIEN | rw   | CTSF interrupt enable<br>0: Interrupt is disabled.<br>1: An interrupt is generated when CTSF is '1' in the USART_STS<br>register.<br>Note: This bit is not available for UART4, UART5, USART6,<br>UART7 and UART8.                                                                                                                                                                                                                                                                                           |
| Bit 9     | CTSEN  | rw   | CTS enable<br>0: CTS hardware flow control is disabled.<br>1: CTS mode is enabled. Data can only be transmitted when the<br>CTS input is asserted (tied low). If the CTS signal is deasserted<br>while a data is being transmitted, then the transmission stops<br>after this data is sent. If a data is written into the data register<br>while CTS is deasserted, the transmission is postponed until<br>CTS is asserted.<br>Note: This bit is not available for UART4, UART5, USART6,<br>UART7 and UART8. |
| Bit 8     | RTSEN  | rw   | RTS enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



| Mai   | ngo     | Hang | zhou Vango Technologies, Inc. 575 / 78                                              |
|-------|---------|------|-------------------------------------------------------------------------------------|
|       |         |      | IrDA modes.                                                                         |
| Bit 2 | IRDALP  | rw   | This bit is used for selecting between normal and low-power                         |
|       |         |      | IrDA low-power                                                                      |
| Bit 3 |         |      | 1: Half-duplex mode is selected.                                                    |
|       | HALFSEL | rw   | 0: Half-duplex mode is not selected.                                                |
|       |         |      | Half-duplex selection Selection of single-wire half-duplex mode                     |
|       |         |      | UART8.                                                                              |
|       |         |      | Note: This bit is not available for UART4, UART5, UART7 and                         |
| Bit 4 | NACKEN  | rw   | 1: NACK is enabled when parity error occurs.                                        |
|       |         |      | 0: NACK is disabled when parity error occurs.                                       |
|       |         |      | Smartcard NACK enable                                                               |
|       |         |      | UART8.                                                                              |
|       |         |      | Note: This bit is not available for UART4, UART5, UART7 and                         |
| Bit 5 | SCMEN   | rw   | 0: Smartcard mode is disabled.<br>1: Smartcard mode is enabled.                     |
|       |         |      |                                                                                     |
|       |         |      | Smartcard mode enable This bit enables Smartcard mode.                              |
|       |         |      | 1: DMA mode is enabled for reception.                                               |
| Bit 6 | DMAREN  | rw   | 0: DMA mode. DMA mode is disabled for reception.                                    |
| l     |         |      | This bit is set and cleared by software.                                            |
|       |         |      | DMA receiver enable                                                                 |
| Die 7 | DIWITER |      | 1: DMA mode is enabled for transmission.                                            |
| Bit 7 | DMATEN  | rw   | 0: DMA mode is disabled for transmission.                                           |
|       |         |      | UART7 and UART8.<br>DMA transmitter enable This bit is set and cleared by software. |
|       |         |      | Note: This bit is not available for UART4, UART5, USART6,                           |
|       |         |      | received.                                                                           |
|       |         |      | The RTS output is asserted (tied low) when data can be                              |
|       |         |      | stop after the current data is transmitted.                                         |
|       |         |      | is space in the receive buffer. The transmission is expected to                     |
|       |         |      | 1: RTS interrupt is enabled. Data is only requested when there                      |
|       |         |      |                                                                                     |

|       |        |    | 0: Normal mode                                                                                                                                                                                                                                                                                                                                                      |
|-------|--------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |    | 1: Low-power mode                                                                                                                                                                                                                                                                                                                                                   |
| Bit 1 | IRDAEN | rw | IrDA mode enable                                                                                                                                                                                                                                                                                                                                                    |
|       |        |    | This bit is set and cleared by software.                                                                                                                                                                                                                                                                                                                            |
|       |        |    | 0: IrDA mode is disabled.                                                                                                                                                                                                                                                                                                                                           |
|       |        |    | 1: IrDA mode is enabled.                                                                                                                                                                                                                                                                                                                                            |
| Bit 0 | ERRIEN | rw | Error interrupt enable<br>In multi-buffer communication mode, an interrupt is generated<br>when framing error, overrun error, or noise error occurs (FERR<br>= 1, or ORERR = 1, or NERR = 1 in USART_STS).<br>0: Interrupt is disabled.<br>1: An interrupt is generated when DMAREN = 1 in<br>USART_CTRL3, and FERR = 1, or ORERR = 1, or NERR = 1 in<br>USART_STS. |

# 15.6.7 Guard Time and Prescaler Register (GTP)

Address offset: 0x18

Reset value: 0x0000

| Bit       | Name       | Туре | Description                                                                                                                                                                                                                                                                  |
|-----------|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | -          | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                      |
| Bit 15:8  | GTVAL[7:0] | rw   | Guard time value<br>This bit-field specifies the guard time value in terms of baud<br>clocks. This function is used in Smartcard mode. The<br>transmission complete flag is set after this guard time. Note:<br>This bit is not available for UART4, UART5, UART7 and UART8. |
| Bit 7:0   | DIV[7:0]   | rw   | Prescaler value<br>- In IrDA low-power mode:<br>DIV[7:0] = IrDA low-power baud rate is used to divide the<br>system clock to obtain the frequency in low-power mode:                                                                                                         |



| The source clock is divided by the value in the register (only 8    |
|---------------------------------------------------------------------|
| significant bits):                                                  |
| 00000000: Reserved – Do not write this value.                       |
| 0000001: Divide the source clock by 1                               |
| 00000010: Divide the source clock by 2                              |
|                                                                     |
| - In IrDA normal mode: DIV must be set to 00000001                  |
| - In Smartcard mode:                                                |
| DIV[4:0]: Prescaler value is used to divide the system clock to     |
| provide clock for the Smartcard.                                    |
| The value in the register (5 low significant bits) is multiplied by |
| 2, as the division factor for the source clock.                     |
| 00000: Reserved – Do not write this value.                          |
| 00001: Divide the source clock by 2                                 |
| 00010: Divide the source clock by 4                                 |
| 00011: Divide the source clock by 6                                 |
|                                                                     |
| Note 1: Bit [7:5] have no effect in Smartcard mode.                 |
| Note 2: This bit is not available for UART4, UART5, UART7 and       |
| UART8.                                                              |



## **16 Serial Peripheral Interface (SPI)**

## **16.1 SPI Introduction**

The SPI interface supports either the SPI protocol or the  $I^2S$  audio protocol.

By default, the SPI function is selected. Users can switch from SPI mode to I<sup>2</sup>S mode by software.

The serial peripheral interface (SPI) allows half/ full-duplex, synchronous, and serial communication with external devices. The interface can be configured as the master, and it provides the communication clock (SCK) for the external slave devices. The interface is also capable of operating in multi-master configuration. It may be used for a variety of purposes, including simplex synchronous transfers on two lines with a bidirectional data line or reliable communication with CRC check.

The I<sup>2</sup>S is also a 3-pin synchronous serial communication interface. It can address four different audio standards, including the I<sup>2</sup>S Philips standard, the MSB and LSB justified standards, and the PCM standard. It can operate as a slave or a master device in half-duplex mode. Master clock can be provided through the interface to an external slave device when the I<sup>2</sup>S functions as a master.

Warning: Since some SPI3/ I2S3 pins are shared with JTAG pins (SPI3\_NSS/ I2S3\_WS with JTDI and SPI3\_SCK/ I2S3\_CK with JTDO), they are not controlled by the I/O controller and are reserved for JTAG usage (after each reset) by default. If users want to configure the SPI3/I2S3 pins, the JTAG must be disabled and switched to the SWD interface (when debugging), or disable both JTAG and SWD interfaces (during standard applications). For more information, please refer to <u>Section 7.4.3</u>.

## 16.2 Main Features

## 16.2.1 SPI Main Features

- Full-duplex synchronous transfers on three lines
- Simplex synchronous transfers on two lines with or without a bidirectional data line
- 8-bit or 16-bit transfer frame format selection
- Master or slave operation



- Multi-master mode capability
- 8 master mode baud rate prescalers (Max. of fPCLK/2)
- Slave mode frequency (Max. of fPCLK/2)
- Fast communication for both master and slave

• NSS management by hardware or software in both master and slave mode: dynamic change of master/slave operations

- Programmable clock polarity and phase
- Programmable data order with MSB-first or LSB-first shifting
- Dedicated transmission and reception flags with interrupt capability
- SPI bus busy status flag
- Hardware CRC for reliable communication:
  - CRC value can be transmitted as the last byte in Tx mode.
  - Automatic CRC error checking on the last received byte in full-duplex mode
- Master mode fault, overrun, and CRC error flags with interrupt capability
- 2-byte transmission and reception buffer with DMA capability: Tx and Rx requests generation

## 16.2.2 I2S Function Overview

- Master or slave operations
- 8-bit programmable linear prescaler to reach accurate audio sample frequencies (from 8 kHz to 192 kHz)
- Data format can be 16 -bit, 24-bit, or 32-bit.

• Packet frame is fixed to 16-bit (16-bit data frame) or 32-bit (16-bit, 24-bit, or 32-bit data frame) by audio channel.

- Programmable clock polarity (steady state)
- Underrun flag in slave transmission mode and overrun flag in master/slave reception mode
- 16-bit data register for transmission and reception, one data register on each channel side
- I<sup>2</sup>S protocols supported
  - I<sup>2</sup>S Philips standard



- MSB-justified standard (left-justified)
- LSB-justified standard (right-justified)
- PCM standard (with short and long frame synchronization on 16 -bit channel frame or 16-bit
- data frame extended to 32-bit channel frame)
- Data direction is always MSB first.
- DMA capability for transmission and reception
- ullet Master clock can output to an external audio component. The ratio is fixed at 256 x Fs (where

Fs is the audio sampling frequency).

## **16.3 Function Overview**

## **16.3.1 SPI Function Overview**

## 16.3.1.1 Introduction

Figure 16-1 is the block diagram of SPI.

Figure 16-1 SPI Block Diagram



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

• MISO: Master In/Slave Out. This pin transmits data in slave mode and receives data in master mode.

• MOSI: Master Out/Slave In. This pin transmits data in master mode and receives data in slave mode.

• SCK: Serial clock, as output for masters and input for slaves

• NSS: Slave select. This is an optional pin which selects master/slave devices. It acts as a "chip select" to allow the SPI master to independently communicate with certain slaves to avoid conflicts on the data lines. Slave NSS pin can be driven by a standard I/O pin on the master device. The NSS pin may also be used as an output if enabled (NSSOE bit) and driven low if the SPI is in master configuration. In this case, all NSS pins from SPI devices connected to the Master NSS pin are at a low level, and become slaves automatically when they are configured in NSS hardware mode. When configured in master mode with NSS configured as an input (MSTEN = 1, NSSOE = 0), the SPI enters fault state of the master mode if NSS is pulled low. In other words, the MSTEN bit is automatically cleared, and the device enters the slave mode.

Figure 16-2 shows an example of the interconnections between a single master and a single slave.

Figure 16-2 Single Master and Single Slave Application



Note: The NSS pin is configured as an input here.

The MOSI pins are connected together, and the MISO pins are connected together. In this way, data is

transferred serially between master and slave (MSB first). The communication is always initiated by the



master. When the master device transmits data to a slave device via the MOSI pin, the slave device responds via the MISO pin. This implies full-duplex communication, with synchronized data out and data in with the same clock signal, which is provided by the master device via the SCK pin.

#### Slave select (NSS) pin management

There are two NSS modes:

• Software NSS mode: This mode is enabled by setting the SWNSSEN bit in the SPI\_CTRL1 register (See Figure 16-3). In this mode, NSS pin remains free for other application uses, while the internal NSS signal is driven by writing the ISS bit in the SPI\_CTRL1 register.

• Hardware NSS mode, which includes two conditions:

— NSS output enabled: When V84XXX works as a master SPI, and NSS output is enabled by setting the NSSOE bit in the SPI\_CTRL2 register, NSS pin is pulled low at this time; all SPI devices, of which NSS pins are connected to this master SPI's NSS pins and configured as hardware NSS, will become slaves automatically. When a SPI device needs to send broadcast data, it must pull NSS signal low to notify other devices that it is the master. If it fails to pull NSS low, this means that there is another master processing communication on the bus, and a hardware failure fault (Hard Fault) will be generated.

NSS output disabled: Allowed in multi-master mode.

Figure 16-3 Hardware/Software Slave Select Management



#### Clock phase and clock polarity

The CPOL and CPHA bits in the SPI\_CTRL1 register can generate four possible timing relationships. The CPOL (clock polarity) bit controls the clock level at idle state when no data is being transferred. This bit takes effect both in master and slave modes. If CPOL is reset, the SCK pin stays low at idle state. If CPOL is set, the SCK pin stays high at idle state.



If the CPHA (clock phase) bit is set, the second edge on the SCK pin (falling edge if the CPOL bit is reset, rising edge if the CPOL bit is set) is the data bit capture strobe. Data are latched on the occurrence of the second clock transition. If the CPHA bit is reset, the first edge on the SCK pin (falling edge if CPOL bit is reset, rising edge if CPOL bit is set) is the data bit capture strobe. Data are latched on the occurrence of the first clock transition.

The combination of the CPOL (clock polarity) and CPHA (clock phase) bits selects the data capture clock edge. Figure 16-4 shows an SPI transfer with the four combinations of the CPHA and CPOL bits. This diagram may be interpreted as a master or slave timing diagram where the SCK pin, the MISO pin, the MOSI pin are directly connected between the master and the slave devices.

**Note:** 1. Before modifying the CPOL/CPHA bits, the SPIEN bit should be cleared to disable SPI.

2. Master and slave must be programmed in the same timing mode.

3. The idle state of SCK must be consistent with the polarity selected in the SPI\_CTRL1 register (at idle state, by pulling up SCK if CPOL = 1 or pulling down SCK if CPOL = 0).

4. The data frame format (8-bit or 16-bit) is selected through the DFF 16 bit in SPI\_CTRL1 register, and it can also be used to determine the data length during transmission/reception.

Figure 16-4 Data Clock Timing Diagram





#### Data frame format

Data can be shifted out either MSB-first or LSB-first, depending on the value of the LSBEN bit in the SPI\_CTRL1 register. Based on the size of the data programmed in the DFF16 bit in the SPI\_CTRL1 register, each data frame is 8 bits or 16 bits long. The selected data frame format is applicable for transmission and/or reception.

### 16.3.1.2 Configure SPI in Slave Mode

In slave mode, the serial clock is received on the SCK pin from the master device. The value set in the MCLKP[4:0] bits in the SPI\_CTRL1 register does not affect the data transfer rate.

Note: It is recommended enabling the SPI slave before the master sends the clock. Otherwise, undesired data transmission might occur. The data register of the slave should be ready before the first edge of the



communication clock or before the end of the ongoing communication. The polarity of the communication clock must be set to a steady state value before the slave and the master are enabled.

Please follow the procedure below to configure SPI in slave mode:

#### Configuration procedure

1. Set the DFF16 bit to select 8-bit or 16-bit data frame format.

2. Configure the CPOL and CPHA bits to define the phase relationships between the data transfer and the serial clock (See Figure 16-4). For correct data transfer, the CPOL and CPHA bits must be configured in the same way in the slave device and the master device.

3. The frame format (MSB-first or LSB-first depending on the LSBEN bit in the SPI\_CTRL1 register) must be the same as the master device.

4. In hardware mode (Please refer to the section of slave select (NSS) pin management), the NSS pin must be connected to a low level signal during the whole byte (8-bit or 16-bit) transmit sequence. In NSS software mode, set the SWNSSEN bit and clear the ISS bit in the SPI\_CTRL1 register.

5. Clear the MSTEN bit and set the SPIEN bit (in the SPI\_CTRL1 register) to assign the pins in SPI mode. In this configuration, the MOSI pin is data input, while the MISO pin is data output.

#### Data transmission procedure

The data byte is parallelly loaded into the Tx buffer during a write operation.

The transmit sequence begins when the slave device receives the clock signal, and the first data bit appears on its MOSI pin (Note: The first bit is sent at this time). The rest of the bits (the 7 bits in 8-bit data frame format; the 15 bits in 16-bit data frame format) are loaded into the shift register. The TE flag in the SPI\_STS register is set when data is transferred from the Tx buffer to the shift register; an interrupt is generated if the TEIE bit in the SPI\_CTRL2 register is set.

#### Data reception procedure

For the receiver, when data transfer is completed:

• interrupt is generated if the RNEIE bit is set in the SPI\_CTRL2 register.

After the last sampling clock edge, the RNE bit is set, data byte received in the shift register is moved to the Rx buffer. When the SPI\_DT register is read, the SPI peripheral returns this buffered value.



The RNE bit is cleared by reading the SPI\_DT register.

## 16.3.1.3 Configure SPI in Master Mode

In the master configuration, the serial clock is generated on the SCK pin.

#### **Configuration procedure**

1. Select the MCLKP[3:0] bits in the SPI\_CTRL1 register to define the serial clock baud rate.

2. Select the CPOL and CPHA bits to define one of the phase relationship between the data transfer and the serial clock (See Figure 16-4).

3. An 16 bit to define 8 -bit or 16-bit data frame format.

4. Configure the LSBEN bit in the SPI\_CTRL1 register to define the frame format.

5. If the NSS pin is required in input mode and hardware mode, connect the NSS pin to a high-level signal during the whole byte transmit sequence. In software mode, set the SWNSSEN and ISS bits in the SPI\_CTRL1 register. If the NSS pin is required in output mode, only the NSSOE bit should be set.

6. The MSTEN and SPIEN bits must be set (They remain set only when the NSS pin is connected to a high-level signal). In this configuration, the MOSI pin is data output, and the MISO pin is data input.

#### Data transmission procedure

The transmit sequence begins when a byte is written in the Tx buffer. The data byte is parallelly loaded into the shift register (from the internal bus) during the first bit transmission, and then is shifted out serially to the MOSI pin; MSB-first or LSB-first depends on the LSBEN bit in the SPI\_CTRL1 register. The TE flag is set when data is transferred from the Tx buffer to the shift register; an interrupt is generated if the TEIE bit in the SPI\_CTRL2 register is set.

#### Data reception procedure

For the receiver, when data transfer is completed:

- Data-in shift register is transferred to Rx buffer, and the RNE flag is set.
- An interrupt is generated if the RNEIE bit is set in the SPI\_CTRL2 register.

After the last sampling clock edge, the RNE bit is set, data byte received in the shift register is moved to the Rx buffer. When the SPI\_DT register is read, the SPI peripheral returns this buffered value.



The RNE bit is cleared by reading the SPI\_DT register. Once the transmission begins, a continuous transmit stream can be maintained if the next data to be transmitted is put into the Tx buffer. Please note that TE flag should be '1' before any attempt to write the Tx buffer is made.

Note: In NSS hardware mode, the NSS input of the slave device is controlled by the NSS pin, or by another GPIO pin driven by software.

## 16.3.1.4 Configure SPI for Half-duplex Communication

The SPI can operate in half-duplex mode with the following 2 configurations:

- 1 clock and 1 bidirectional data wire
- 1 clock and 1 data wire (receive-only or transmit-only)

#### 1 clock and 1 bidirectional data wire (BDMODE = 1)

This mode is enabled by setting the BDMODE bit in the SPI\_CTRL1 register. In this mode, the SCK pin is used as the clock; MOSI in master mode and MISO in slave mode are used for data communication. The transfer direction is selected by the BDOE bit in the SPI\_CTRL1 register. When this bit is '1', the data line is output; otherwise, it is input.

#### 1 clock and 1 unidirectional data wire (BDMODE = 0)

In this mode, SPI can either be transmit-only or receive-only.

• Transmit-only mode is similar to full-duplex mode (BDMODE = 0, RONLY = 0): Data is transmitted on the transmit pin (MOSI in master mode or MISO in slave mode), and the receive pin (MISO in master mode or MOSI in slave mode) can be used as a general-purpose I/O. In this case, the software can ignore data in the Rx buffer (If the data register is read, it does not contain any received data).

• In receive-only mode, the SPI output function can be disabled by setting the RONLY bit in the SPI\_CTRL2 register. In this case, the transmit pin (MOSI in master mode or MISO in slave mode) is released, so it can be used for other purposes.

To start the communication in receive-only mode, configure the SPI as follows:

• In master mode, the communication starts immediately once the SPI is enabled. After the SPIEN bit is cleared, the communication stops when it completes current reception. There is no need to read the BSY flag in this mode. It always remains set when SPI communication is ongoing.

• In slave mode, the SPI continues to receive as long as the NSS is pulled down (or the ISS bit is



Hangzhou Vango Technologies, Inc.

cleared in NSS software mode), and at the same time the SCK has clock pulse.

## 16.3.1.5 Data Transmission and Reception

#### **Rx and Tx buffers**

In reception, received data are stored into an internal Rx buffer; in transmission, data are first stored into an internal Tx buffer before being transmitted.

A read access to the SPI\_DT register returns the Rx buffered value; data written to the SPI\_DT will be written into the Tx buffer.

#### Start sequence in master mode

- In full-duplex mode (BDMODE = 0 and RONLY = 0)
  - The sequence begins when data is written into the SPI\_DT register (Tx buffer).

 Data is parallelly loaded from the Tx buffer into the 8-bit shift register during the first bit transmission, and then shifted out serially to the MOSI pin.

— At the same time, the received data on the MISO pin is serially shifted into the 8-bit shift register and then parallelly loaded into the SPI\_DT register (Rx buffer).

- In unidirectional receive-only mode (BDMODE = 0 and RONLY = 1)
  - The sequence begins as soon as SPIEN = 1.

— Only the receiver is activated, and the received data on the MISO pin are shifted serially into the 8bit shift register and then are parallelly loaded into the SPI\_DT register (Rx buffer).

- In bidirectional mode, when transmitting (BDMODE = 1 and BDOE = 1)
  - The sequence begins when data are written into the SPI\_DT register (Tx buffer).

— The data are then parallelly loaded from the Tx buffer into the 8-bit shift register during the first bit transmission, and then are shifted out serially to the MOSI pin.

- No data is received.
- In bidirectional mode, when receiving (BDMODE = 1 and BDOE = 0)
  - The sequence begins as soon as SPIEN = 1 and BDOE = 0.

— The received data on the MOSI pin are serially shifted into the 8-bit shift register and then are parallelly loaded into the SPI\_DT register (Rx buffer).

- The transmitter is not activated, and no data is shifted out serially to the MOSI pin.

ango

#### Start sequence in slave mode

• In full-duplex mode (BDMODE = 0 and RONLY = 0)

— The sequence begins when the slave device receives the clock signal, and the first data bit appears on its MOSI pin. The remaining bits are loaded into the shift register one after another.

— At the same time, the data are parallelly loaded from the Tx buffer into the 8-bit shift register during the first bit transmission, and then are shifted out serially to the MISO pin. The software must write the data to be sent into the Tx register before the SPI master device initiates the transfer.

• In unidirectional receive-only mode (BDMODE = 0 and RONLY = 1)

— The sequence begins when the slave device receives the clock signal, and the first data bit appears on its MOSI pin. Then, the remaining bits are loaded into the shift register one after another.

- The transmitter is not activated, and no data is shifted out serially to the MISO pin.

• In bidirectional mode, when transmitting (BDMODE = 1 and BDOE = 1)

The sequence begins when the slave device receives the clock signal, and the first data bit in the
 Tx buffer is sent to the MISO pin.

— When the first data bit is sent to the MISO pin, the data to be sent in the Tx buffer are parallelly loaded into the 8-bit shift register, and then are shifted out serially to the MISO pin. The software must write the data to be sent into the Tx register before the SPI master device initiates the transfer.

No data is received.

• In bidirectional mode, when receiving (BDMODE = 1 and BDOE = 0)

 The sequence begins when the slave device receives the clock signal, and the first data bit appears on its MISO pin.

 The received data on the MISO pin is serially shifted into the 8-bit shift register and then are parallelly loaded into the SPI\_DT register (Rx buffer).

- The transmitter is not activated, and no data are serially shifted out to the MISO pin.

#### Handling data transmission and reception

The TE flag (Tx buffer empty) is set when the data is transferred from the Tx buffer to the shift register. It indicates that the internal Tx buffer is ready to be loaded with the next data. An interrupt will be generated if the TEIE bit in the SPI\_CTRL2 register is set. Writing to the SPI\_DT register can clear the TE bit.



Note: The software must ensure that the TE flag is set to 1 before attempting to write to the Tx buffer. Otherwise, it overwrites the data that is previously written to the Tx buffer.

The RNE flag (Rx buffer not empty) is set on the last sampling clock edge, when the data are transferred from the shift register to the Rx buffer. It indicates that data are ready to be read from the SPI\_DT register. An interrupt will be generated if the RNEIE bit in the SPI\_CTRL2 register is set. Reading the SPI\_DT register can clear the RNE bit.

For some configurations, the BSY flag can be used during the last data transfer to wait for completion of the transfer.

# Full-duplex transmit and receive procedure in master or slave mode (BDMODE = 0 and RONLY = 0)

The software should follow the procedure below to transmit and receive data (See Figure 16-5 and Figure 16-6):

1. Enable the SPI by setting the SPIEN bit to 1.

2. Write the first data to be transmitted into the SPI\_DT register, and this clears the TE flag.

3. Wait until TE = 1, and then write the second data to be transmitted. Then, wait until RNE = 1 and read the SPI\_DT register to get the first received data; at the same time, reading the SPI\_DT register will clear the RNE bit. Repeat this procedure to transmit the remaining data while receiving the n - 1 data.

4. Wait until RNE = 1, and read the last received data.

5. Wait until TE = 1, and then disable the SPI after BSY = 0.

This procedure can also be implemented to handle the interrupts generated at rising edges of the corresponding RNE or TE flags.

Figure 16-5 TE/RNE/BSY Behavior during Continuous Output in Master/Full-duplex Mode (BDMODE = 0 and RONLY = 0)





Figure 16-6 TE/RNE/BSY Behavior during Continuous Transfer in Slave/Full-duplex Mode (BDMODE = 0 and RONLY = 0)





#### Transmit-only procedure (BDMODE = 0 and RONLY = 0)

In this mode, the procedure can be briefly described as follows, and the BSY bit can be used to wait until the end of the transmission (See Figure 16-7 and Figure 16-8):

1. Enable the SPI by setting the SPIEN bit to '1'.

2. Write the first data item to be sent into the SPI\_DT register, and this clears the TE flag.

3. Wait until TE = 1, and then write the next data item to be transmitted. Repeat this step for each data item to be transmitted.

4. After writing the last data item into the SPI\_DT register, wait until TE = 1; then, wait until BSY =0, which indicates that the transmission of the last data is completed.

This procedure can also be implemented to handle the interrupts generated at rising edges of the corresponding TE flags.

**Note:** 1. During discontinuous communications, there is a 2-APB clock period delay between the write operation to the SPI\_DT register and setting the BSY bit. As a consequence, in transmit-only mode, it is recommended that users wait until TE = 1, and then wait until BSY = 0 after writing the last data.



2. After transmitting two data items in transmit-only mode, the OVR bit becomes '1' in the SPI\_STS register since the received data will not be read (Note: Software can ignore this OVR flag bit).

Figure 16-7 TE/BSY Behavior during Continuous Transfer in Master Transmit-only Mode (BDMODE = 0 and RONLY = 0)



Figure 16-8 TE/BSY Behavior during Continuous Transfer in Slave Transmit-only Mode (BDMODE = 0 and RONLY = 0)

| Example of salve mode CPOL = 1, CPHA = 1                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Data 1 = 0×F1         Data 2 = 0×F2         Data 3 = 0×F3           MISO/MOSI(Output)         b0         b1         b2         b3         b4         b5         b6         b7         b0         b1         b2         b3         b4         b5         b6         b7         b0         b1         b2         b3         b4         b5         b6         b7         b0         b1         b2         b3         b4         b5         b6         b7 |
| TE flag Set by hardware and Set by hardware and Set by hardware and Set by hardware Set by hardware                                                                                                                                                                                                                                                                                                                                                   |
| Tx buffer<br>(Write SPI_DT)                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Software     Software waits       until TE = 1 and                                                                                                                                                                                                                                                                                                                                                                                                    |
| writes 0×F1<br>then writes 0×F2<br>to SPI_DT<br>worker value of the stand<br>then writes 0×F2<br>to SPI_DT<br>worker value of the stand<br>then writes 0×F3<br>to SPI_DT                                                                                                                                                                                                                                                                              |

#### Bidirectional transmit procedure (BDMODE = 1 and BDOE = 1)

ango

In this mode, the procedure is similar to the procedure in transmit-only mode, except that the BDMODE



and BDOE bits have to be set at the same time in the SPI\_CTRL1 register before enabling the SPI.

#### Unidirectional receive-only procedure (BDMODE = 0 and RONLY = 1)

In this mode, the procedure can be briefly described as follows, (See Figure 16-9):

1. Set RONLY = 1 in the SPI\_CTRL1 register.

2. Set SPIEN = 1 to enable the SPI:

a) In master mode, this immediately generates the SCK clock, and data will be continuously received until the SPI is disabled (SPIEN = 0).

b) In slave mode, serial data will be received when the SPI master device drives the NSS signal low and generates the SCK clock.

3. Wait until RNE = 1, and then read the SPI\_DT register to obtain the received data (this clears the RNE bit). Repeat this operation for each data item to be received.

This procedure can also be implemented to handle the interrupts generated at rising edges of the corresponding RNE flags.

*Note: If the SPI is disabled after the last transfer, please follow the recommended* procedure in Section 16.3.1.9.

Figure 16-9 RNE Behavior during Continuous Transfer in Receive-only Mode (BDMODE = 0 and RONLY = 1)



#### Bidirectional receive procedure (BDMODE = 1 and BDOE = 0)

In this mode, the procedure is similar to the receive-only mode procedure, except that the BDMODE bit

has to be set '1', and the BDOE bit is cleared in the SPI\_CTRL2 register before enabling the SPI.



#### **Continuous and discontinuous transfers**

When transmitting data in master mode, if the software is fast enough to detect each rising edge of TE (or TE interrupts) and to immediately write to the SPI\_DT register before the end of ongoing data transfer, then continuous communication can be achieved. In this case, continuity of the SPI clock between each data transfer is maintained, and the BSY bit will not be cleared.

On the contrary, if the software is not fast enough, then it leads to discontinuities in the communication. In this case, the BSY bit is cleared between each data transmission (See Figure 16-10). In master receive-only mode (RONLY = 1), the communication is always continuous, and the BSY flag is always '1'. In slave mode, the continuity of the communication is determined by the SPI master device. In any case, even if the communication is continuous, the BSY flag goes low between each transfer for at least one SPI clock cycle (See Figure 16-8).





## 16.3.1.6 CRC Calculation

CRC calculation is implemented for full-duplex communication reliability. Separate CRC calculators are used for the transmitted data and received data. The CRC is calculated through a programmable polynomial computation on each bit. It is performed on the sampling clock edge defined by the CPHA and CPOL bits in the SPI\_CTRL1 register.

Note: This SPI offers two kinds of CRC calculation methods which depend on the data frame format selected for the transmission and/or reception. 8-bit data frame adopts CRC8; 16-bit data frame



adopts CRC16.

CRC calculation is enabled by setting the CCE bit in the SPI\_CTRL1 register, and this action also resets the CRC registers (SPI\_RCRC and SPI\_TCRC). After the CTN bit in SPI\_CTRL1 is set, the content in SPI\_TCRC will be transmitted after the current byte is sent.

When transferring the content of SPI\_TCRC, if the data received in the shift register does not match with the content of SPI\_RCRC, then the CERR bit in the SPI\_STS register is set.

If data is still present in the Tx buffer, the CRC value is transmitted only after the end of data byte transmission. During CRC transmission, the CRC calculator is switched off, and the register value remains unchanged.

Note: Please refer to the product instruction to check if there is CRC calculation (This function is not available on every model).

SPI communication with CRC is enabled through the following procedure:

- Program the CPOL, CPHA, LSBEN, MCLKP, SWNSSEN, ISS, and MSTEN values.
- Program the polynomial in the SPI\_CPOLY register.

• Enable CRC calculation by setting the CCE bit in the SPI\_CTRL1 register. This also clears the SPI\_RCRC and SPI\_TCRC registers.

• Enable the SPI by setting the SPIEN bit in the SPI\_CTRL1 register.

• Start the communication and keep the communication until the last byte or half-word.

• When writing the last byte or half-word to the Tx buffer, set the CTN bit in the SPI\_CTRL1 register to indicate that the CRC value will be transmitted after the hardware transmission of the last byte. During CRC value transmission, CRC calculation is stopped.

• After the transfer of the last byte or half-word, the SPI sends the CRC value, and the CTN bit is cleared. Likewise, the received CRC is compared to the SPI\_RCRC value. If the values do not match, the CERR flag in SPI\_STS is set, and an interrupt is generated when the ERRIE bit in the SPI\_CTRL2 register is set.

*Note: 1. When the SPI is in slave mode, please note that CRC calculation is only enabled* after the clock becomes stable. Otherwise, the CRC calculation may be wrong. In fact, once the CCE bit is set, the CRC calculation is performed if input clock is present on the SCK pin, no matter what the SPIEN bit status is.



2. With high SPI clock frequencies, be careful when transmitting the CRC. During CRC transmission, make the time to use CPU as short as possible; it is forbidden to call software functions in the CRC transmission sequence to avoid errors in the last data and CRC reception. The CTN bit must be set before the end of the last data transmission/reception.

3. For high SPI clock frequencies, it is advised to use the DMA mode to avoid the degradation of the SPI speed performance, since CPU accesses would affect the SPI bandwidth.

4. When V84XXX is configured as slave mode, and NSS hardware mode is used, the NSS pin should remain low during data transfer and CRC transfer.

When the SPI is configured in slave mode with the CRC function enabled, CRC calculation is performed even if a high level is applied on the NSS pin. (Note: When the NSS signal is high, if clock pulse is present on the SCK pin, then CRC calculation is kept being performed.) For example, this may happen in a multislave environment where the communication master addresses several slaves alternately. (Note: In this case, CRC misoperation should be avoided.)

## 16.3.1.7 Status Flag

Three status flags are provided for the application to completely monitor the state of the SPI bus.

#### Tx buffer empty flag (TE)

When this flag is set, it indicates that the Tx buffer is empty, and the next data to be transmitted can be loaded into the buffer. The TE flag is cleared when writing to the SPI\_DT register.

#### **Rx buffer not empty (RNE)**

When set, this flag indicates that there are valid received data in the Rx buffer. It is cleared when the SPI data register is read.

#### **Busy flag**

The BSY flag is set and cleared by hardware (writing to this flag has no effect). The BSY flag indicates the state of the SPI communication layer.

When BSY is set, it indicates that the SPI is busy communicating. There is one exception: In bidirectional master receive mode (MSTEN = 1, BDM = 1, and BDOE = 0), the BSY flag is kept low during reception.

The BSY flag is useful to detect the end of a transfer if the software wants to disable the SPI and enter Halt mode (or disable the peripheral clock). This avoids corrupting the last transfer. Therefore, the



procedure described below must be strictly followed.

The BSY flag is also useful to avoid write collisions in a multi-master system.

The BSY flag is set when a transfer starts, except for bidirectional receive mode of master mode (MSTEN

= 1, BDM = 1, and BDOE = 0).

This flag is cleared under the following conditions:

- When a transfer is finished. (Except for the continuous communication in master mode)
- When the SPI is disabled.
- When a master mode fault occurs (MODF = 1).

If the communication is not continuous, the BSY flag is low between each data item transfer. When the communication is continuous:

- In master mode: The BSY flag is kept high during the whole transfer procedure.
- In slave mode: The BSY flag goes low for one SPI clock cycle between each data transfer.

*Note: Do not use the BSY flag to handle every data transmission or reception. It is better to use the TE and RNE flags instead.* 

### 16.3.1.8 Disabling SPI

When communication is completed, disabling the SPI peripheral can stop the communication. This is done by clearing the SPIEN bit. For some configurations, disabling the SPI and entering the Halt mode while a transfer is ongoing may corrupt the current transfer, and/or the BSY flag might become unreliable.

To avoid this situation, it is recommended that users follow the procedure below when disabling the SPI:

#### In master or slave full-duplex mode (BDMODE = 0, RONLY = 0)

- 1. Wait until RNE = 1 and receive the last data
- 2. Wait until TE = 1
- 3. Wait until BSY = 0
- 4. Disable the SPI (SPIEN = 0), and finally enter the Halt mode (or disable the peripheral clock).

# In master or slave unidirectional transmit-only mode (BDMODE = 0, RONLY = 0) or bidirectional transmit mode (BDMODE = 1, BDOE = 1)

After the last data is written into the SPI\_DT register:



1. Wait until TE = 1

2. Wait until BSY = 0

3. Disable the SPI (SPIEN = 0), and finally enter the Halt mode (or disable the peripheral clock).

# In master unidirectional receive-only mode (MSTEN = 1, BDMODE = 0, RONLY = 1) or bidirectional receive mode (MSTEN = 1, BDMODE = 1, BDOE = 0)

This case should be managed in a particular way to ensure that the SPI does not initiate a new transfer:

1. Wait for the second to last (n - 1) occurrence of RNE = 1

2. Wait for one SPI clock cycle before disabling the SPI (SPIEN = 0) (using a software delay)

3. Wait for the last RNE = 1 before entering the Halt mode (or disabling the peripheral clock)

Note: In master unidirectional receive-only mode (MSTEN = 1, BDM = 1, BDOE = 0), the BSY flag is always kept low during the transfers.

# In slave receive-only mode (MSTEN = 0, BDMODE = 0, RONLY = 1) or bidirectional receive mode (MSTEN = 0, BDMODE = 1, BDOE = 0)

1. Users can disable the SPI (SPIEN = 0) at any time, and the SPI will be disabled after the current transfer is finished.

 If users want to enter the Halt mode, users must first wait until BSY = 0 before entering the Halt mode (or disabling the peripheral clock).

## 16.3.1.9 SPI Communication Using DMA

To reach the maximum of communication speed, the SPI transmit buffer needs to be filled with data in time; likewise, the data received on the Rx buffer should be read in time to avoid overrun. To facilitate effective transfers, the SPI features a DMA capability which adopts a simple request/acknowledge protocol.

A DMA access is requested from the DMA when the corresponding enable bit in the SPI\_CTRL2 register is set. Separate requests must be issued to the Tx and Rx buffers.

• In transmission, a DMA request is issued each time when TE is set to '1'. The DMA controller then writes data to the SPI\_DT register, which clears the TE flag.

• In reception, a DMA request is issued each time when RNE is set to `1'. The DMA controller then reads the SPI\_DT register, which clears the RNE flag.



When only the SPI is used to transmit data, only the SPI Tx DMA channel needs to be enabled. In this case, the OVR flag is set because the data received is not read (Note: Software can ignore this flag). When only the SPI is used to receive data, only the SPI Rx DMA channel needs to be enabled.

In transmission mode, when the DMA transfers all the data to be transmitted (The TCIF flag becomes '1' in the DMA\_ISTS register), the BSY flag can be monitored to ensure that the SPI communication is completed. This can avoid corrupting the last transmission before disabling the SPI or entering the Stop mode. Therefore, the software must first wait until TE = 1 and then BSY = 0.

Note: During discontinuous communications, there is a 2-APB clock period delay between the write operation to SPI\_DT and setting the BSY bit. As a consequence, it is necessary to wait first until TE = 1, and then until BSY = 0 after writing the last data.



Figure 16-11 Transmission using DMA

Figure 16-12 Reception using DMA



#### **DMA capability with CRC**

When the SPI is enabled with CRC check and DMA mode, the transmission and reception of the CRC are automatically completed at the end of communication.

At the end of data and CRC transfers, the CERR flag in SPI\_STS is '1' if corruption occurs during the transfer.

### 16.3.1.10 Error Flag

#### Master mode fault (MODF)

Master mode fault occurs only when: In NSS pin hardware mode, the master device has its NSS pin pulled low; or in NSS pin software mode, the ISS bit is set as '0'; this automatically sets the MODF bit. Master mode fault affects the SPI peripheral in the following ways:

- The MODF bit is set, and an SPI interrupt is generated if the ERRIE bit is set.
- The SPIEN bit is cleared. This blocks all outputs from the device and disables the SPI interface.
- The MSTEN bit is cleared, thus forcing the device into slave mode. Use the following sequence to clear the MODF bit:
- 1. Perform a read or write access to the SPI\_STS register when the MODF bit is set.
- 2. Then write to the SPI\_CTRL1 register.

To avoid multiple slave conflicts in a system with several MCUs, the NSS pin of the master device must be pulled high before clearing the MODF bit. The SPIEN and MSTEN bits can be restored to their original states after the clearing sequence.



For security purposes, hardware does not allow the setting of the SPIEN and MSTEN bits when the MODF bit is set.

In normal configuration, the MODF bit in a slave device cannot be set. However, in a multi-master configuration, the device can be in slave mode with this MODF bit set. In this case, the MODF bit indicates that there might be a multi-master conflict. An interrupt routine can be used to recover from fault state by resetting or returning to default state.

#### **Overrun error**

An overrun condition occurs when the master device sends data bytes, but the slave device does not clear the RNE bit resulting from the previous data byte. When an overrun condition occurs:

• The OVR bit is set '1'; an interrupt is generated if the ERRIE bit is set.

In this case, the contents in Rx buffer will not be updated with the newly received data from the master device. A read from the SPI\_DT register returns the previous unread byte. All other subsequently transmitted bytes are lost.

Reading the SPI\_DT register and SPI\_STS register one after another can clear the OVR bit.

#### **CRC error**

When the CCE bit is set in the SPI\_CTRL register, the CRC error flag is used to verify the validity of the value received. If the value received in the shift register (the SPI\_TCRC value sent by the transmitter) does not match with the value of the receiver (the SPI\_RCRC register), the CRCEN bit in the SPI\_STS register will be set.

### 16.3.1.11 SPI Interrupt

| Interrupt Event          | Event Flag | Enable Control Bit |  |  |
|--------------------------|------------|--------------------|--|--|
| Tx buffer empty flag     | TE         | TEIE               |  |  |
| Rx buffer not empty flag | RNE        | RNEIE              |  |  |
| Master mode fault event  | MODF       |                    |  |  |
| Overrun error            | OVR        | ERRIE              |  |  |
| CRC error flag           | CERR       |                    |  |  |

Table 16-1 SPI Interrupt Request



## **16.3.2 I2S Function Overview**

All V84XXX products support  $I^2S$  audio protocol.

## 16.3.2.1 I2S Function Overview

Figure 16-13 is the block diagram of  $I^2S$ :

Figure 16-13 I<sup>2</sup>S Block Diagram



Setting the I2SSEL bit in the SPI\_I2SCTRL register can enable I<sup>2</sup>S function. In this case, the SPI functions



as an audio  $I^2S$  interface. Generally speaking, this  $I^2S$  interface uses the same pins, flags, and interrupts as the SPI.

The  $I^2S$  shares three common pins with the SPI:

• SD: Serial data (mapped on the MOSI pin) for transmitting or receiving the data of two timemultiplexed channels

• WS: Word select (mapped on the NSS pin) as data control signal output in master mode; input in slave mode

• CK: Serial clock (mapped on the SCK pin) as clock signal output in master mode; input in slave mode

• For some external audio devices which require master clock, an additional pin could be used to output clock.

• MCLK: Master clock (mapped independently) is used to output additional clock signal when I<sup>2</sup>S is configured as master mode and the I2SMCLKOE bit in the SPI\_I2SCLKP register is set. The frequency of output clock signal is set to 256×Fs by default, where Fs is the audio signal sampling frequency.

When set in master mode, I<sup>2</sup>S uses its own clock generator to produce the communication clock signal. This clock generator is also the source of the master clock output. Two additional registers are available in I<sup>2</sup>S mode; one is SPI\_I2SCLKP, which is used to configure the clock generator, and the other is generic I<sup>2</sup>S configuration register, SPI\_I2SCTRL (which configures audio standard, slave/master mode, data format, packet frame, and clock polarity, etc.).

The SPI\_CTRL1 register and all CRC registers are not used in the I<sup>2</sup>S mode. Likewise, the NSSOE bit in the SPI\_CTRL2 register and the MODF and CERR bits in the SPI\_STS are not used. I<sup>2</sup>S uses the same register, SPI\_DR, as SPI for data transfer in 16-bit wide mode

## 16.3.2.2 Supported Audio Protocol

The three-line bus supports audio data time-multiplexed on two channels: the right channel and the left channel. However, there is only one 16-bit register for the transmission and the reception. Hence, the software should write the corresponding value of the current transmission channel into the data register; likewise, identify the corresponding channel by checking the I2SCS bit in the SPI\_STS register when



reading data from the data register. The left channel is always sent first, followed by the right channel (The I2SCS bit has no meaning for the PCM protocol).

Four data and packet frames are available. Data can be sent with the following four formats:

- 16-bit data packed in 16 -bit frame
- 16-bit data packed in 32 -bit frame
- 24-bit data packed in 32 -bit frame
- 32-bit data packed in 32 -bit frame

When using 16-bit data extended on 32-bit packet, the first 16 bits (MSB) are the significant bits, and the subsequent 16-bit (LSB) is forced to 0 without software action or DMA request (only one read/write operation is needed).

The 24-bit and 32-bit data frames require two CPU read or write operations to/from the SPI\_DT register or two DMA transfers if the DMA is used. For 24-bit data frame, when it is extended to 32-bit, the 8 least significant bits are set '0' by hardware. For all data formats and communication standards, the most significant bit (MSB) is always sent first.

The I<sup>2</sup>S interface supports four audio standards, which are configurable with the I2SAP[1:0] and PCMSYNCSEL bits in the SPI\_I2SCTRL register.

#### I<sup>2</sup>S Philips standard

In this standard, the WS pin is used to indicate the channel of which data is being transmitted. It is activated one clock cycle before the first bit (MSB) is sent.

Figure 16-14 I<sup>2</sup>S Philips Protocol Waveforms (16bit/32-bit full accuracy, CPOL = 0)



Data are transmitted on the falling edge of CK by the transmitter, and are read on the rising edge by the





Figure 16-15 I<sup>2</sup>S Philips Protocol Standard Waveforms (24-bit frame, CPOL = 0)



This mode needs two write or read operations to/from the SPI\_DT register.

• In transmission mode: If 0x8EAA33 has to be sent (24-bit):

Figure 16-16 Transmitting 0x8EAA33



• In reception mode: If 0x8EAA33 has to be received:

Figure 16-17 Receiving 0x8EAA33



Figure 16-18 I<sup>2</sup>S Philips Protocol Standard Waveforms (16-bit extended to 32-bit frame, CPOL = 0)



When 16-bit data frame extended to 32-bit channel frame is selected at the I<sup>2</sup>S configuration phase, only



one access to SPI\_DT is required. The 16 remaining bits are forced by hardware to 0x0000 to extend the data to 32-bit format.

If data to be transmitted or the received data are 0x76A3 (0x76A30000 if extended to 32-bit), the operation shown in Figure 16-19 is required.

Figure 16-19 Example



During transmission, MSB should be written to SPI\_DT; the TE flag bit is set, indicating that new data can be written, and its interrupt, if allowed, is generated. The transmission is done by hardware; TE is set, and the corresponding interrupt is generated even if 16-bit 0x0000 is not yet sent.

For reception, the RNE flag is set, and its interrupt, if allowed, is generated each time when the first 16 half-word (MSB) is received.

In this way, more time is provided between two write and read operations, which prevents underrun or overrun conditions.

#### **MSB-justified standard**

In this standard, the WS signal and the first data bit, which is the MSB bit, are generated at the same time.





Data are changed on the falling edge of clock signal for transmitter and are read on the rising edge for



the receiver.

Figure 16-21 MSB-justified 24-bit Data, CPOL = 0



Figure 16-22 MSB-justified 16-bit Data Extended to 32-bit Frame, CPOL = 0



#### LSB-justified standard

This standard is similar to the MSB-justified standard (no difference between the 16-bit and 32-bit fullaccuracy frame formats).

Figure 16-23 LSB-justified 16-bit or 32-bit Full-accuracy, CPOL = 0



Figure 16-24 LSB-justified 24-bit Data, CPOL = 0





• In transmission mode

If data 0x3478AE is to be transmitted, two write operations to the SPI\_DT register are required through software or by DMA. The operations are shown in Figure 16-25.

Figure 16-25 Operations Required to Transmit 0x3478AE



#### • In reception mode

If data 0x3478AE is to be received, two read operations from SPI\_DT are required on two consecutive

RNE events, respectively.

Figure 16-26 Operations Required to Receive 0x3478AE



Figure 16-27 LSB-justified 16-bit Data Extended to 32-bit Frame, CPOL = 0



When 16-bit data frame extended to 32-bit channel frame is selected at the I<sup>2</sup>S configuration phase, only one access to SPI\_DT is required. The first half-word (16-bit MSB) are forced to 0x0000 by hardware to extend the data to 32-bit format.

If the data to be transmitted or the received data are 0x76A3 (0x000076A3 if extended to 32-bit), the operation shown in Figure 16-28 is required.

Figure 16-28 Example

Only one access to SPI\_DR is required

0×76A3

During transmission, if TE is '1', users have to write the data to be transmitted (0x76A3 in this case). The 0x0000 field used for extension on 32-bit is transmitted first. The next TE event occurs as soon as valid data begins to be sent from the SD pin. In reception mode, RNE is asserted as soon as the significant half-word is received (instead of the 0x0000 field). In this way, more time is provided between two write or read operations to prevent underrun or overrun conditions.

#### **PCM standard**

In PCM standard, there is no information on channel selection. Two frames, short and long frame, are available for PCM standard, and they can be configured with the PCMSYNCSEL bit in the SPI\_I2SCTRL register.



Figure 16-29 PCM Standard Waveform (16-bit)

For long frame in slave mode, the WS signal assertion time is fixed at 13 bits for synchronization. As for



short frame, the WS signal assertion time is only 1 bit for synchronization.



Figure 16-30 PCM Standard Waveform (16-bit extended to 32-bit package frame)

Note: For both modes (master and slave) and for both synchronizations (short and long), the number of bits between two consecutive pieces of data and two synchronization signals needs to be specified by the DLEN bit and the CHLEN bit in the SPI\_I2SCTRL register (even in slave mode).

## 16.3.2.3 Clock Generator

The I<sup>2</sup>S bitrate determines the dataflow on the I<sup>2</sup>S data line and the I<sup>2</sup>S clock signal frequency. I<sup>2</sup>S bitrate = number of bits per channel × number of channels × sampling audio frequency For a 16-bit audio signal with left and right channels, the I<sup>2</sup>S bitrate is calculated as follows: I<sup>2</sup>S bitrate =  $16 \times 2 \times Fs$ 

If the packet length is 32-bit wide, then:  $I^2S$  bitrate =  $32 \times 2 \times Fs$ 

Figure 16-31 Definition of Audio Sampling Frequency



In master mode, the linear divider should be configured correctly and properly to obtain the desired audio



#### Figure 16-32 I<sup>2</sup>S Clock Generator Architecture



In Figure 16-32, the I2SxCLK source is the system clock (HSI, HSE, or PLL that drives the AHB clock). The audio sampling frequency can be 192 kHz, 96 kHz, 48 kHz, 44.1 kHz, 32 kHz, 22.05 kHz, 16 kHz,

11.025 kHz, or 8 kHz (or any other values within this range). In order to reach the desired frequency, the linear divider needs to be programmed according to the formulas below:

When the master clock is generated (the I2SMCLKOE bit is '1' in the SPI\_I2SCLKP register): When the channel frame is 16-bit wide, Fs = I2SxCLK/ [(16\*2)\*((2\*I2SDIV) + I2SODD)\*8] When the channel frame is 32-bit wide, Fs = I2SxCLK/ [(32\*2)\*((2\*I2SDIV) + I2SODD)\*4] When the master clock is disabled (the I2SMCLKOE bit is '0'):

When the channel frame is 16-bit wide, Fs = I2SxCLK/ [(16\*2) \* ((2\*I2SDIV) + I2SODD)] When the channel frame is 32-bit wide, Fs = I2SxCLK/[(32\*2) \* ((2\*I2SDIV) + I2SODD)]

Table 16-2 provides an example of the precision values for different clock configurations.

*Note: Other configurations can also be used to achieve the optimum clock precision.* 

| SysCLK | MCLK | TargetFs | 16bit  |         |          | 32bit |        |         |          |       |
|--------|------|----------|--------|---------|----------|-------|--------|---------|----------|-------|
| (MHz)  |      | (Hz)     | I2sDIV | I2S_ODD | RealFs   | Error | I2sDIV | I2S_ODD | RealFs   | Error |
| 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% |

 Table 16-2 Audio-frequency Precision Using System Clock



| 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         792.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         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         16000         12         0         16276.04         1.73%         12         0         16276.04         1.73%           100         Yes         1000         12         1         1160.71         1.23%         17         1         1116.071         <                                                                                                                                                         |     |     |        |     |   |          |        | - 17474 |   |          |        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|--------|-----|---|----------|--------|---------|---|----------|--------|
| 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         4828.13         1.73%         4         0         4828.13         1.73%           100         Yes         44100         4         1         43402.78         1.58%         4         1         43402.78         1.58%           100         Yes         2000         6         0         32552.08         1.73%         6         0         32552.08         1.73%           100         Yes         16000         12         0         16276.04         1.73%         12         0         16276.04         1.73%           100         Yes         10005         24         1         7971.939         0.35%         24         1         7971.939         0.35%           72         No         192000         6         0         187500         2.34%         1         1         48913.04         1.                                                                                                                                                             | 100 | No  | 16000  | 97  | 1 | 16025.64 | 0.16%  | 49      | 0 | 15943.88 | 0.35%  |
| 100         Yes         9600         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         16000         12         0         16276.04         1.73%         12         0         16276.04         1.73%           100         Yes         1005         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         19200         6         0         187500         2.34%         11         1         48913.04         1                                                                                                                                                             | 100 | No  | 11025  | 141 | 1 | 11042.4  | 0.16%  | 71      | 0 | 11003.52 | 0.19%  |
| 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         2000         6         0         32552.08         1.73%         6         0         32552.08         1.73%           100         Yes         16000         12         0         16276.04         1.73%         12         0         16276.04         1.73%           100         Yes         1005         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         48000         32         1         34615.38         27.8%         11         1         48913.04 <t< td=""><td>100</td><td>No</td><td>8000</td><td>195</td><td>1</td><td>7992.327</td><td>0.10%</td><td>97</td><td>1</td><td>8012.821</td><td>0.16%</td></t<>       | 100 | No  | 8000   | 195 | 1 | 7992.327 | 0.10%  | 97      | 1 | 8012.821 | 0.16%  |
| 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         2050         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         1002         Yes         1002         12         0         16276.04         1.73%         12         0         16276.04         1.73%           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         48000         32         1         34615.38         27.8%         11         1 <td>100</td> <td>Yes</td> <td>96000</td> <td>2</td> <td>0</td> <td>97656.25</td> <td>1.73%</td> <td>2</td> <td>0</td> <td>97656.25</td> <td>1.73%</td>          | 100 | Yes | 96000  | 2   | 0 | 97656.25 | 1.73%  | 2       | 0 | 97656.25 | 1.73%  |
| 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         48000         32         1         34615.38         27.88%         11         1         48913.04         1.90%           72         No         44000         25         1         22058.2         0.04%         15         1         2142.86         0.                                                                                                                                                             | 100 | Yes | 48000  | 4   | 0 | 48828.13 | 1.73%  | 4       | 0 | 48828.13 | 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         32000         35         0         32142.86         0.45%         17         1         32142.86         0.45                                                                                                                                                             | 100 | Yes | 44100  | 4   | 1 | 43402.78 | 1.58%  | 4       | 1 | 43402.78 | 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                                                                                                                                                             | 100 | Yes | 32000  | 6   | 0 | 32552.08 | 1.73%  | 6       | 0 | 32552.08 | 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         16000         70         1         15957.45         0.27%         35         0         16071.43         0.45%<                                                                                                                                                             | 100 | Yes | 22050  | 9   | 0 | 21701.39 | 1.58%  | 9       | 0 | 21701.39 | 1.58%  |
| 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         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% </td <td>100</td> <td>Yes</td> <td>16000</td> <td>12</td> <td>0</td> <td>16276.04</td> <td>1.73%</td> <td>12</td> <td>0</td> <td>16276.04</td> <td>1.73%</td> | 100 | Yes | 16000  | 12  | 0 | 16276.04 | 1.73%  | 12      | 0 | 16276.04 | 1.73%  |
| 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         32000         35         0         32142.86         0.45%         17         1         32142.86         0.45%           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% <td>100</td> <td>Yes</td> <td>11025</td> <td>17</td> <td>1</td> <td>11160.71</td> <td>1.23%</td> <td>17</td> <td>1</td> <td>11160.71</td> <td>1.23%</td>       | 100 | Yes | 11025  | 17  | 1 | 11160.71 | 1.23%  | 17      | 1 | 11160.71 | 1.23%  |
| 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         32000         35         0         32142.86         0.45%         17         1         32142.86         0.45%           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.2                                                                                                                                                             | 100 | Yes | 8000   | 24  | 1 | 7971.939 | 0.35%  | 24      | 1 | 7971.939 | 0.35%  |
| 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         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 <td< td=""><td>72</td><td>No</td><td>192000</td><td>6</td><td>0</td><td>187500</td><td>2.34%</td><td>3</td><td>0</td><td>187500</td><td>2.34%</td></td<>            | 72  | No  | 192000 | 6   | 0 | 187500   | 2.34%  | 3       | 0 | 187500   | 2.34%  |
| 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         18000         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         6.29%         3         0         46875         6.29% </td <td>72</td> <td>No</td> <td>96000</td> <td>11</td> <td>1</td> <td>97826.09</td> <td>1.90%</td> <td>6</td> <td>0</td> <td>93750</td> <td>2.34%</td>       | 72  | No  | 96000  | 11  | 1 | 97826.09 | 1.90%  | 6       | 0 | 93750    | 2.34%  |
| 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         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         6.29%         3         0         46875         6.29% </td <td>72</td> <td>No</td> <td>48000</td> <td>32</td> <td>1</td> <td>34615.38</td> <td>27.88%</td> <td>11</td> <td>1</td> <td>48913.04</td> <td>1.90%</td>  | 72  | No  | 48000  | 32  | 1 | 34615.38 | 27.88% | 11      | 1 | 48913.04 | 1.90%  |
| 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         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         2.34%         4         1         31250         2.34%                                                                                                                                                                      | 72  | No  | 44100  | 25  | 1 | 44117.65 | 0.04%  | 13      | 0 | 43269.23 | 1.88%  |
| 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         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  | No  | 32000  | 35  | 0 | 32142.86 | 0.45%  | 17      | 1 | 32142.86 | 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         32000         4         1         31250         2.34%         4         1         31250         2.34%           72         Yes         32000         6         1         21634.62         1.88%         6         1         21634.62         1.88%                                                                                                                                                                                      | 72  | No  | 22050  | 51  | 0 | 22058.82 | 0.04%  | 25      | 1 | 22058.82 | 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       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       32000       4       1       31250       2.34%       4       1       31250       2.34%         72       Yes       32000       6       1       21634.62       1.88%       6       1       21634.62       1.88%         72       Yes       16000       9       0       15625       2.34%       9       0                                                                                                                                                                                                                                                                                   | 72  | No  | 16000  | 70  | 1 | 15957.45 | 0.27%  | 35      | 0 | 16071.43 | 0.45%  |
| 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       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       32000       4       1       31250       2.34%       4       1       31250       2.34%         72       Yes       32000       4       1       31250       2.34%       4       1       31250       2.34%         72       Yes       16000       9       0       15625       2.34%       9       0       15625       2.34%         72       Yes       16000       9       0       15625       2.34%       9       0       15625 <td>72</td> <td>No</td> <td>11025</td> <td>102</td> <td>0</td> <td>11029.41</td> <td>0.04%</td> <td>51</td> <td>0</td> <td>11029.41</td> <td>0.04%</td>                                                                                                                            | 72  | No  | 11025  | 102 | 0 | 11029.41 | 0.04%  | 51      | 0 | 11029.41 | 0.04%  |
| 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       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       32000       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       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  | No  | 8000   | 140 | 1 | 8007.117 | 0.09%  | 70      | 1 | 7978.723 | 0.27%  |
| 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         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         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 | 96000  | 2   | 0 | 70312.5  | 26.76% | 2       | 0 | 70312.5  | 26.76% |
| 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       16000       9       0       15625       2.34%       9       0       15625       2.34%         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 | 48000  | 3   | 0 | 46875    | 2.34%  | 3       | 0 | 46875    | 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 | 44100  | 3   | 0 | 46875    | 6.29%  | 3       | 0 | 46875    | 6.29%  |
| 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 | 32000  | 4   | 1 | 31250    | 2.34%  | 4       | 1 | 31250    | 2.34%  |
| 72         Yes         11025         13         0         10817.31         1.88%         13         0         10817.31         1.88%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 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         8000         17         1         8035.714         0.45%         17         1         8035.714         0.45%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 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%  |

# 16.3.2.4 I2S Master Mode

When  $I^2S$  is configured in master mode, the serial clock is generated on the CK pin, and the Word Select



signal is generated on the WS pin. Whether the master clock (MCLK) is output or not can be configured by the I2SMCLKOE bit in the SPI\_I2SCLKP register.

#### Procedure

1. Set I2SDIV[9:0] in the SPI\_I2SCLKP register to define the serial clock baud rate corresponding to audio sample frequency. The I2SODD bit in the SPI\_I2SCLKP register also needs to be defined.

2. Set the CPOL bit to define the steady level for the communication clock. Set the MCLKOE bit in the SPI\_I2SCLKP register if the master clock, MCLK, needs to be provided to the external DAC/ADC audio component (The I2SDIV and I2SODD values should be computed depending on the state of the MCLK output. For more details, please refer to Section 16.3.2.3).

3. Set the I2SSEL bit in the SPI\_I2SCTRL register to activate the I<sup>2</sup>S function, and select the I<sup>2</sup>S standard through the I2SAP[1:0] and PCMSYNCSEL bits. Set the data length through the DATLEN[1:0] bits. Select the number of bits per channel by configuring the CHLEN bit. Also set I2SMOD[1:0] in the SPI\_I2SCTRLI2S register to select I<sup>2</sup>S master mode and direction (transmitter or receiver).

4. If needed, enable the desired interrupt and the DMA capabilities by writing the SPI\_CTRL2 register.

5. The I2SEN bit in the SPI\_I2SCTRL register must be set.

6. WS and CK pins need to be configured in output mode. The MCLK pin is also set as an output, if the I2SMCLKOE bit in SPI\_I2SCLKP is set.

#### **Transmission sequence**

The transmission sequence begins when a half-word (16-bit) is written into the Tx buffer. Assume that the first data written into the Tx buffer corresponds to the left channel data. When data are transferred from the Tx buffer to the shift register, TE is set, and at this time data corresponding to the right channel have to be written into the Tx buffer. The I2SCS flag indicates which channel corresponds to the current data to be transmitted. The value of I2SCS is updated when TE is '1', so it will be meaningful when the TE is '1'.

A full frame is recognized at the end of a left channel data transmission followed by a right channel data transmission. It is not possible to have a partial frame where only the left channel is sent.

The half-word data is parallelly loaded into the 16-bit shift register during the first bit transmission, and then the following bits are shifted out serially, MSB first, to the MOSI/SD pin. The TE flag is set after each data transfer from the Tx buffer to the shift register. An interrupt is generated if the TEIE bit in the



SPI\_CTRL2 register is set.

For more details about the write operations depending on the  $I^2S$  standard mode selected, please refer to <u>Section 16.3.2.2</u>.

To ensure a continuous audio data transmission, it is advised to write the SPI\_DT register with the next data to be transmitted before the end of the current transmission. When writing the last data, wait until TE = 1 and BSY = 0, and then disable I<sup>2</sup>S function by clearing the I2SEN bit.

#### **Reception sequence**

The operation of reception sequence mode is the same as the transmission mode, except for the point 3 (Please refer to the previous section of "transmission sequence"), where the master reception mode is selected by configuring I2SMOD[1:0]. Whatever the data or channel length is, the audio data are received as 16-bit packets. This means that each time when the Rx buffer is full, the RNE flag is set, and an interrupt is generated if the RNEIE bit is set in the SPI\_CTRL2 register. According to the data and channel length configured, the audio value received for a right or left channel may require one or two receptions into the Rx buffer.

Reading the SPI\_DT register can clear the RNE flag bit.

I2SCS is updated after each reception. It is sensitive to the WS signal generated by the  $I^2S$  cell.

For more details about the read operations depending on the selected  $I^2S$  standard mode, please refer to <u>Section 16.3.2.2</u>.

If new data is received while the previously received data is not read yet, an overrun is generated, and the OVR flag is set. If the ERRIE bit is set in the SPI\_CTRL2 register, an interrupt is generated to indicate the error.

To switch off the I<sup>2</sup>S, specific actions are required to ensure that the I<sup>2</sup>S completes the transfer cycle properly without initiating a new data transfer. The sequence depends on the configuration of the data and channel lengths, also the audio protocol mode selected. Please refer to the following:

• 16-bit data extended on 32 -bit channel length (DLEN = 00 and CHLEN = 1), in LSB- justified mode (I2SAP = 10)

a) Wait for the second to last (n - 1) RNE = 1



b) Then, wait 17 I<sup>2</sup>S clock cycles (using a software loop)

c) Disable  $I^2S$  (I2SEN = 0)

• 16-bit data extended on 32 -bit channel length (DLEN = 00 and CHLEN = 1 ), in MSB-justified,

 $I^2S$ , or PCM modes (I2SAP = 00, or I2SAP = 01, or I2SAP = 11)

a) Wait for the last RNE = 1

b) Then, wait 1 I<sup>2</sup>S clock cycle (using a software loop)

c) Disable the  $I^2S$  (I2SEN = 0)

• For all other combinations of DLEN and CHLEN, whatever the audio mode is selected through

I2SAP, carry out the following sequence to switch off  $I^2S$ :

a) Wait for the second to last (n - 1) RNE = 1

b) Then, wait 1 I<sup>2</sup>S clock cycle (using a software loop)

c) Disable  $I^2S$  (I2SEN = 0)

Note: The BSY flag is always kept low during transfers.

## 16.3.2.5 I<sup>2</sup>S Slave Mode

In slave mode, the I<sup>2</sup>S can be configured in transmission or reception mode. The operating mode mainly follows the same rules as described in the I<sup>2</sup>S master configuration. In slave mode, I<sup>2</sup>S interface does not need to provide the clock. The clock and WS signals are provided by the external I<sup>2</sup>S master, connected to the corresponding pins. Therefore, users do not have to configure the clock.

The configuration steps are as follows:

1. Set the I2SSEL bit in the SPI\_I2SCTRL register to activate the I<sup>2</sup>S function; configure I2SAP[1:0] to select desired I<sup>2</sup>S standard; program DLEN[1:0] to select the bit number of data; configure CHLEN to choose number of bit per channel. Select data direction (transmission or reception) in I<sup>2</sup>S slave mode through I2SMOD[1:0] in the SPI\_I2SCTRL register.

2. If needed, enable interrupt and DMA functions by setting the SPI\_CTRL2 register.

3. The I2SEN bit in SPI\_I2SCTRL register must be set.



#### Transmission sequence

The transmission sequence begins when the external master device sends the clock, and when the NSS\_WS signal requests data transfer. The slave has to be enabled and the I<sup>2</sup>S data register has to be loaded before the external master starts the communication.

For the I<sup>2</sup>S MSB justified and LSB justified modes, the first data item written into the data register corresponds to the left channel data. When the communication starts, the data is transferred from the Tx buffer to the shift register. The TE flag is then set, and the data corresponding to the right channel is written into the I<sup>2</sup>S data register.

The I2SCS flag indicates that data to be transmitted corresponds to which channel. Compared to the master transmission mode, in slave mode, I2SCS is sensitive to the WS signal from the external  $I^2S$  master. This means that the  $I^2S$  slave needs to be ready to transmit the first data before the clock is

generated by the master. For I<sup>2</sup>S MSB-justified and LSB-justified mode, WS signal assertion means the left channel transmitted first.

*Note: The I2SEN bit has to be set at least two PCLK cycles before the first clock signal of* the I2S master on the CK pin.

Half-word data is parallelly loaded into the 16-bit shift register from the I<sup>2</sup>S internal bus during the first bit transmission, and then is serially shifted out to the MOSI/SD pin, MSB first. The TE flag is set after each transfer from the Tx buffer to the shift register, and an interrupt is generated if the TEIE bit in the SPI\_CTRL2 register is set.

Note: Before any attempt to write the Tx buffer, ensure that the TE flag is '1'.

For more details about the write operations depending on the I<sup>2</sup>S standard mode selected, please refer to <u>Section 16.3.2.2</u>. To secure a continuous audio data transmission, it is advised to write the SPI\_DT register with the next data to be transmitted before the end of the current transmission. An underrun flag is set and an interrupt may be generated if the new data is not written into the SPI\_DT register before the first clock edge of the next data communication. This indicates that there is software data transmission error. If the ERRIE bit is set in the SPI\_CTRL2 register, an interrupt is generated when the UDR flag in the SPI\_STS register goes high. In this case, it is suggested to switch off the I<sup>2</sup>S and to



restart a data transfer starting from the left channel.

When the last data is written, clear the I2SEN bit after waiting until TE = 1 and BSY = 0 to switch off the  $I^2S$ .

#### **Reception sequence**

The configuration procedure is the same as the transmission mode except for the point 1, where the I2SMOD[1:0] bits are configured to select master reception mode. Whatever the data length or the channel length is, the audio data is always received as 16-bit packets. This means that each time the Rx buffer is full, the RNE flag is set, and an interrupt is generated if the RNEIE bit is set in the SPI\_CTRL2 register. Depending on the data length and channel length configuration, the audio value received for a right or left channel may need one or two receptions into the Rx buffer.

The I2SCS flag is updated at each data reception (to be read from SPI\_DT). It is sensitive to the external WS signal generated by I<sup>2</sup>S cell.

Reading the SPI\_DT register, will clear the RNE bit.

For more details about the read operations depending on the selected I<sup>2</sup>S standard, please refer to <u>Section 16.3.2.2</u>.

If new data is received while the precedent received data is not read, an overrun is generated, and the OVR flag is set. If the ERRIE bit is set in the SPI\_CTRL2 register, an interrupt is generated to indicate the error.

To switch off  $I^2S$  in reception mode, the I2SEN bit has to be cleared immediately after receiving the last RNE = 1.

*Note: The external*  $I^2S$  *master components should have the capability of sending/receiving* data in 16bit or 32-bit packets via an audio channel.

#### 16.3.2.6 Status Flag

Four status flags are provided for users to monitor the state of the  $I^2S$  bus.

#### Busy flag (BSY)

The BSY flag is set and cleared by hardware (writing to this flag has no effect). It indicates the state of



the I<sup>2</sup>S communication layer.

When BSY is set, it indicates that  $I^2S$  is busy communicating, but here is one exception: In master receive mode (I2SMOD = 11), the BSY flag is always kept low during reception.

The BSY flag can be used to detect the end of a transfer before the software disables SPI. This avoids corrupting the last transfer. Therefore, the procedure described below must be strictly followed.

The BSY flag is set when a transfer starts, unless the  $I^2S$  is in master receiver mode. The BSY flag is cleared:

• When a transfer completes (except for master transmit mode, in which the communication is continuous).

- When  $I^2S$  is disabled. When communication is continuous:
- In master transmit mode, the BSY flag is kept high during all the transfers.
- In slave mode, the BSY flag goes low for one I <sup>2</sup>S clock cycle between each transfer.

*Note: Do not use the BSY flag for each data transmission or reception. It is better to* use the TE and RNE flags.

#### Tx buffer empty flag (TE)

When set, this flag indicates that the Tx buffer is empty, and the next data to be transmitted can then be loaded into it. The TE flag is reset when the Tx buffer already contains data to be transmitted. It is also reset when the  $I^2S$  is disabled (the I2SEN bit is '0').

#### Rx buffer not empty flag (RNE)

When set, this flag indicates that there are valid received data in the Rx buffer. It is reset when the SPI\_DT register is read.

#### Channel side flag (I2SCS)

In transmission mode, this flag is refreshed when TE goes high. It indicates the channel side to which the data from the SD pin is transferred. If an underrun error occurs in slave transmission mode, the value of this flag is invalid. The I<sup>2</sup>S needs to be switched off and then switched on before resuming the communication.

In reception mode, this flag is refreshed when data is received into SPI\_DT. It indicates from which



channel side data is received.

Note: If errors occur (such as overrun, OVR), this flag becomes meaningless, and  $I^2S$  should be reset and then enabled again (also, change the I2S configuration if needed).

This flag is meaningless in the PCM standard for both short and long frame modes.

When the OVR or UDR flag in SPI\_STS is set and the ERRIE bit in SPI\_CTRL2 is also set, an interrupt is generated. This interrupt can be cleared by reading the SPI\_STS register (once the interrupt source is cleared).

### 16.3.2.7 Error Flag

There are two error flags for the  $I^2S$  cell.

#### Underrun flag (UDR)

In slave transmission mode, this flag is set when the first clock edge for data transmission arrives, but new data is not yet loaded into the SPI\_DT register. This bit is valid when the I2SSEL bit in SPI\_I2SCTRL is set. An interrupt is generated if the ERRIE bit in SPI\_CTRL2 is set.

The UDR bit is cleared by a read operation to the SPI\_STS register.

#### Overrun flag (OVR)

Overrun errors occur and the flag is set when new data is received, but the previous received data is not yet read. An interrupt is generated if the ERRIE bit is set in SPI\_CTRL2, to indicate that an error occurs.

In this case, the contents of Rx buffer are not updated with the newly received data from the transmitter device. A read operation to the SPI\_DT register returns the previous correctly received data. All other subsequently transmitted 16-bit data after the overrun event are lost.

The bit is cleared by a read operation to the SPI\_STS register followed by a read operation to the SPI\_DT register.

#### 16.3.2.8 I2S Interrupt

Table 16-3 lists all the I<sup>2</sup>S interrupts.

| Table 16-3 I <sup>2</sup> S Interrupt Reques |
|----------------------------------------------|
|----------------------------------------------|

| Interrupt Event | Event Flag                      | Enable Flag  |
|-----------------|---------------------------------|--------------|
| Jango           | langzhou Vango Technologies, In | c. 620 / 782 |

| Tx buffer empty flag     | TE  | TEIE  |
|--------------------------|-----|-------|
| Rx buffer not empty flag | RNE | RNEIE |
| Overrun Flag             | OVR |       |
| Underrun Flag            | UDR | ERRIE |

## 16.3.2.9 DMA Function

DMA works in exactly the same way as in the  $I^2S$  mode and in SPI mode, except that the CRC feature is

not available in  $I^2S$  mode since there is no data transfer protection system.

# **16.4 SPI Registers**

# 16.4.1 SPI Control Register 1 (SPI\_CTRL1) (Not Used in I2S Mode)

Address offset: 0x00

| Bit    | Name   | Туре | Description                                                                                                                                                                                                                                                                                                                                                                            |
|--------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15 | BDMODE | rw   | <ul> <li>Bidirectional data mode enable</li> <li>0: "2-line unidirectional" mode is selected.</li> <li>1: "1-line bidirectional" mode is selected.</li> <li>Note: This bit is not used in I<sup>2</sup>S mode.</li> </ul>                                                                                                                                                              |
| Bit 14 | BDOE   | rw   | Output enable in bidirectional mode<br>This bit and the BDMODE bit together determine the data<br>output direction in "1-line bidirectional" mode.<br>0: Output is disabled. (Receive-only mode)<br>1: Output is enabled. (Transmit-only mode)<br>The data line is MOSI pin in master mode, and the MISO pin<br>in slave mode.<br>Note: This bit is not used in I <sup>2</sup> S mode. |



|        |         |    | Hardware CRC calculation enable                                |
|--------|---------|----|----------------------------------------------------------------|
|        |         |    |                                                                |
|        |         |    | 0: CRC calculation is enabled.                                 |
|        |         |    | 1: CRC calculation is disabled.                                |
| Bit 13 | CCE     | rw | Note 1: This bit should be written only when SPI is disabled   |
|        |         |    | (SPIEN = 0), else an error may occur. It can only be used in   |
|        |         |    | full-duplex mode.                                              |
|        |         |    | Note 2: This bit is not used in I <sup>2</sup> S mode.         |
|        |         |    | Transmit CRC next                                              |
|        |         |    | 0: Next transmitted value comes from Tx buffer.                |
| Bit 12 | CTN     |    | 1: Next transmitted value comes from Tx CRC register.          |
| DIC 12 | CTN     | rw | Note 1: This bit is set once the last data is written into the |
|        |         |    | SPI_DT register                                                |
|        |         |    | Note 2: This bit is not used in I <sup>2</sup> S mode.         |
|        |         |    | Data frame format                                              |
|        | DFF16   |    | 0: 8-bit data frame format is selected for                     |
|        |         |    | transmission/reception.                                        |
|        |         |    | 1: 16-bit data frame format is selected for transmission/      |
| Bit 11 |         | rw | reception.                                                     |
|        |         |    | Note 1: This bit should be written only when SPI is disabled   |
|        |         |    | (SPIEN = 0), else an error may occur.                          |
|        |         |    | Note 2: This bit is not used in I <sup>2</sup> S mode.         |
|        |         |    | Receive only                                                   |
|        |         |    | This bit and the BDMODE bit together determine the transfer    |
|        |         |    | direction in "2-line bidirectional" mode. In multi-slave       |
|        |         |    | configuration, this bit is set on the slave that is never      |
| Bit 10 | RONLY   | rw | accessed. Thus, only the accessed slaves have output, which    |
|        |         |    | avoids conflicts on data lines.                                |
|        |         |    | 0: Full-duplex (Transmission and reception)                    |
|        |         |    | 1: Output is disabled (Receive-only mode).                     |
|        |         |    | Note: This bit is not used in I <sup>2</sup> S mode.           |
| Bit 9  | SWNSSEN | rw | Software slave management                                      |
|        | 1       | 1  |                                                                |



|         |            |    | When SWNSSEN is set, NSS pin level is determined by the     |
|---------|------------|----|-------------------------------------------------------------|
|         |            |    | ISS bit.                                                    |
|         |            |    | 0: Software slave management is disabled.                   |
|         |            |    | 1: Software slave management is enabled.                    |
|         |            |    | Note: This bit is not used in I <sup>2</sup> S mode.        |
|         |            |    | Internal slave select                                       |
|         |            |    | This bit has meaning only when the SWNSSEN bit is set. It   |
| Bit 8   | ISS        | rw | determines the level on the NSS, and I/O operations on the  |
|         |            |    | NSS pin are invalid.                                        |
|         |            |    | Note: This bit is not used in I <sup>2</sup> S mode.        |
|         |            |    | Frame format                                                |
|         |            |    | 0: MSB first                                                |
|         |            |    | 1: LSB first                                                |
| Bit 7   | LSBEN      | rw | Note 1: This bit cannot be changed when communication is    |
|         |            |    | ongoing.                                                    |
|         |            |    | Note 2: This bit is not used in I <sup>2</sup> S mode.      |
|         |            |    |                                                             |
|         |            |    | SPI enable                                                  |
|         |            |    | 0: SPI is disabled.                                         |
| Bit 6   | SPIEN      | rw | 1: SPI is enabled.                                          |
|         |            |    | Note 1: This bit is not used in I <sup>2</sup> S mode.      |
|         |            |    | Note 2: When SPI is to be disabled, follow the procedure in |
|         |            |    | <u>Section 16.3.1.8</u> .                                   |
|         |            |    | Baud rate control                                           |
|         |            |    | MCLKP[3] bit is in SPI_CTRL2 register, MCLKP[3:0]:          |
|         |            |    | 0000: f <sub>PCLK</sub> /2                                  |
|         | MCLKP[2:0] | rw | 0001: f <sub>PCLK</sub> /4                                  |
| Bit 5:3 |            |    | 0010: f <sub>PCLK</sub> /8                                  |
|         |            |    | 0011: f <sub>PCLK</sub> /16                                 |
|         |            |    | 0100: f <sub>PCLK</sub> /32                                 |
|         |            |    | 0101: f <sub>PCLK</sub> /64                                 |
|         | •          | •  |                                                             |



| -     |       | 1   |                                                           |
|-------|-------|-----|-----------------------------------------------------------|
|       |       |     | 0110: f <sub>PCLK</sub> /128                              |
|       |       |     | 0111: f <sub>PCLK</sub> /256                              |
|       |       |     | 1000: f <sub>PCLK</sub> /512                              |
|       |       |     | 1001: f <sub>PCLK</sub> /1024                             |
|       |       |     | These bits cannot be changed when communication is        |
|       |       |     | ongoing. They can be changed only when SPIEN is disabled. |
|       |       |     | Note: This bit is not used in I <sup>2</sup> S mode.      |
|       |       |     | Master selection                                          |
|       |       |     | 0: Slave configuration                                    |
| Bit 2 | MSTEN | 544 | 1: Master configuration                                   |
|       | MSTEN | rw  | Note 1: This bit cannot be changed when communication is  |
|       |       |     | ongoing.                                                  |
|       |       |     | Note 2: This bit is not used in I <sup>2</sup> S mode.    |
|       |       |     | Clock polarity                                            |
|       |       |     | 0: SCK keeps low at idle state. 1: SCK keeps high at idle |
|       |       |     | state.                                                    |
| Bit 1 | CPOL  | rw  | Note 1: This bit cannot be changed when communication is  |
|       |       |     | ongoing.                                                  |
|       |       |     | Note 2: This bit is not used in I <sup>2</sup> S mode.    |
|       |       |     | Clock phase                                               |
|       |       |     | 0: Data capture starts from the first clock edge.         |
| Dit O | СРНА  |     | 1: Data capture starts from the second clock edge.        |
| Bit 0 |       | rw  | Note 1: This bit cannot be changed when communication is  |
|       |       |     | ongoing.                                                  |
|       |       |     | Note 2: This bit is not used in I <sup>2</sup> S mode.    |
| L     | I     | 1   |                                                           |

# 16.4.2 SPI Control Register 2 (SPI\_CTRL2)

Address offset: 0x04



|          |          | 1      |                                                             |
|----------|----------|--------|-------------------------------------------------------------|
| Bit 15:9 | -        | -      | Reserved. Forced to be '0' by hardware.                     |
| Bit 8    |          |        | Baud rate control                                           |
| DILO     | MCLKP[3] | rw     | Please refer to MCLKP[2:0] in the SPI_CTRL1 register.       |
|          |          |        | Tx buffer empty interrupt enable                            |
|          |          |        | 0: TE interrupt is disabled.                                |
| Bit 7    | TEIE     | rw     | 1: TE interrupt is enabled. An interrupt is generated when  |
|          |          |        | the TE flag is set.                                         |
|          |          |        | Rx buffer not empty interrupt enable                        |
|          |          |        |                                                             |
| Bit 6    | RNEIE    | rw     | 0: RNE interrupt is disabled.                               |
|          |          |        | 1: RNE interrupt is enabled. An interrupt is generated when |
|          |          |        | the RNE flag is set.                                        |
|          |          |        | Error interrupt enable                                      |
|          |          |        | This bit controls interrupt generation when errors occur    |
| Bit 5    | ERRIE    | rw     | (CERR, OVR, or MODF).                                       |
|          |          |        | 0: Error interrupt is disabled.                             |
|          |          |        | 1: Error interrupt is enabled.                              |
| Bit 4:3  | -        | -      | Reserved. Forced to be '0' by hardware.                     |
|          |          |        | SS output enable                                            |
|          |          |        | 0: SS output is disabled in master mode, and the device can |
|          | NSSOE    | 544    | work in multi-master mode.                                  |
| Bit 2    | NSSOL    | rw     | 1: SS output is enabled in master mode when the device is   |
|          |          |        | activated. The device cannot work in multimaster mode.      |
|          |          |        | Note: This bit is not used in I <sup>2</sup> S mode.        |
|          |          |        | DMA Tx enable                                               |
|          |          |        | When this bit is set, DMA request will be sent once the TE  |
| Bit 1    | DMATEN   | rw     | flag is set.                                                |
|          |          |        | 0: Tx buffer DMA is disabled.                               |
|          |          |        | 1: Tx buffer DMA is enabled.                                |
| Rit O    |          |        | DMA Rx enable                                               |
| Bit 0    | DMAREN   | rw     | When this bit is set, DMA request will be sent once the RNE |
| Mang     | 0        | Hangzh | ou Vango Technologies, Inc. 625 / 782                       |

|  |  | flag is set.                  |
|--|--|-------------------------------|
|  |  | 0: Rx buffer DMA is disabled. |
|  |  | 1: Rx buffer DMA is enabled.  |

# 16.4.3 SPI Status Register (SPI\_STS)

Address offset: 0x08

| Bit      | Name                                        | Туре | Description                                                                                                                                                                                                                                                                                           |  |  |
|----------|---------------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit 15:8 | -                                           | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                               |  |  |
| Bit 7    | BSY                                         | r    | <ul> <li>Busy flag</li> <li>0: SPI is not busy.</li> <li>1: SPI is busy, or the Tx buffer is not empty. This bit is set or reset by hardware.</li> <li>Note: Special attention must be given to the use of this flag, please refer to <u>Section 16.3.1.7</u> and <u>Section 16.3.1.8</u>.</li> </ul> |  |  |
| Bit 6    | OVR                                         | r    | Overrun flag<br>0: No overrun error<br>1: Overrun error occurs.<br>This bit is set by hardware and reset by software sequence.<br>For more details about the software sequence, please refer<br>to <u>Section 16.3.2.7</u> .                                                                          |  |  |
| Bit 5    | MODF                                        | r    | Mode fault<br>0: No mode fault<br>1: Mode fault occurs.<br>This bit is set by hardware and reset by software sequence.<br>For more details about the software sequence, please refer<br>to <u>Section 16.3.1.10</u> .<br>Note: This bit is not used in I <sup>2</sup> S mode.                         |  |  |
| Bit 4    | CERR                                        | r_w0 | CRC error flag<br>0: The received CRC value matches with the value in the                                                                                                                                                                                                                             |  |  |
| ango     | Hangzhou Vango Technologies, Inc. 626 / 782 |      |                                                                                                                                                                                                                                                                                                       |  |  |



|       |            |   | SPI_RCRC register.                                             |
|-------|------------|---|----------------------------------------------------------------|
|       |            |   | 1: The received CRC value does not match with the value in     |
|       |            |   | the SPI_RCRC register.                                         |
|       |            |   | This bit is set by hardware and reset by software writing '0'. |
|       |            |   | Note: This bit is not used in I <sup>2</sup> S mode.           |
|       |            |   | Underrun flag                                                  |
|       |            |   | 0: No underrun error                                           |
|       |            | r | 1: Underrun error occurs.                                      |
| Bit 3 | UDR        | r | This bit is set by hardware and reset by software              |
|       |            |   | sequence, please refer to Section 16.3.2.7.                    |
|       |            |   | Note: This bit is not used in SPI mode.                        |
|       |            |   | Channel side                                                   |
|       |            |   | 0: Channel left is to be transmitted or received.              |
| Bit 2 | I2SCS      | r | 1: Channel right is to be transmitted or received.             |
|       |            |   | Note: This bit is not used in SPI mode, and has no meaning     |
|       |            |   | in PCM mode.                                                   |
|       |            |   | Transmit buffer empty                                          |
| Bit 1 | TE         | r | 0: Tx buffer is not empty.                                     |
|       |            |   | 1: Tx buffer is empty.                                         |
|       |            |   | Receive buffer not empty                                       |
| Bit 0 | RNE        | r | 0: Rx buffer is empty.                                         |
|       |            |   | 1: Rx buffer is not empty.                                     |
|       | <u> </u> , |   | . ,                                                            |

# 16.4.4 SPI Data Register (SPI\_DT)

Address offset: 0x0C

| Bit      | Name     | Туре | Description                                                      |
|----------|----------|------|------------------------------------------------------------------|
| Bit 15:0 | DT[15:0] | rw   | Data register<br>Data to be transmitted or data already received |



| The data register includes 2 buffers: One for writing (T  | x       |
|-----------------------------------------------------------|---------|
| buffer) and the other one for reading (Rx buffer).        |         |
| A write operation will send data into the Tx buffer; a re | ead     |
| operation will return the data held in the Rx buffer.     |         |
| Note for SPI mode:                                        |         |
| Depending on the data frame format selection, the DFF     | -16 bit |
| in the SPI_CTRL1 register, the data sent or received is   | either  |
| 8-bit or 16-bit. This selection has to be made before er  | nabling |
| the SPI to ensure correct operation.                      |         |
| For 8-bit data frame, the buffers are 8-bit, and only the | e       |
| SPI_DT[7:0] is used for transmission/reception. In rece   | eption  |
| mode, SPI_DT[15:8] is forced to 0.                        |         |
| For 16-bit data frame, the buffers are 16-bit and the en  | ntire   |
| data register, SPI_DT[15:0], is used for transmission/    |         |
| reception.                                                |         |

# 16.4.5 SPI CRC Polynomial Register (SPI\_CPOLY) (Not Used in I2S Mode)

Address offset: 0x10

| Bit      | Name        | Туре | Description                                                                                                                                                                                                                            |
|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | CPOLY[15:0] | rw   | CRC polynomial register<br>This register contains the polynomial used for CRC<br>calculation. Its reset value is 0x0007, which can be changed<br>according to the application.<br>Note: This bit is not used in I <sup>2</sup> S mode. |



# 16.4.6 SPIRxCRC Register (SPI\_RCRC) (Not Used in I2S Mode)

Address offset: 0x14

Reset value: 0x0000

| Bit      | Name       | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | RCRC[15:0] | r    | Rx CRC register<br>When CRC calculation is enabled, RCRC[15:0] contains the<br>CRC value computed based on the received bytes. This<br>register is reset when the CCE bit in SPI_CTRL1 register is<br>written `1'. The CRC is calculated with the polynomial<br>programmed in the SPI_CPOLY register.<br>Only the 8 LSB bits are considered when the data frame<br>format is set to 8-bit data. CRC calculation is done based on<br>CRC8 standard. The entire 16 bits of this register are<br>considered when 16-bit data frame format is selected. CRC<br>calculation is done based on CRC16 standard.<br>Note 1: A read to this register when the BSY flag is set may<br>return an incorrect value.<br>Note 2: These bits are not used in I <sup>2</sup> S mode. |

# 16.4.7 SPITxCRC Register (SPI\_TCRC)

Address offset: 0x18

| Bit 15:0       TCRC[15:0]       r       Tx CRC register         When CRC calculation is enabled, TCRC[15:0] contains the<br>CRC value computed based on the bytes to be transmitted.         This register is reset when the CCE bit of SPI_CTRL1 is | Bit      | Name       | Туре | Description                                                                                                       |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|------|-------------------------------------------------------------------------------------------------------------------|--|
|                                                                                                                                                                                                                                                      | Bit 15:0 | TCRC[15:0] | r    | When CRC calculation is enabled, TCRC[15:0] contains the CRC value computed based on the bytes to be transmitted. |  |



|  | written '1'. The CRC is calculated with the polynomial        |
|--|---------------------------------------------------------------|
|  | programmed in the SPI_CPOLY register.                         |
|  | Only the 8 LSB bits are considered when the data frame        |
|  | format is set to 8-bit. CRC calculation is done based on CRC8 |
|  | standard. The entire 16 bits of this register are considered  |
|  | when a 16-bit data frame format is selected. CRC calculation  |
|  | is done based on CRC16 standard.                              |
|  | Note: A read to this register when the BSY flag is set may    |
|  | return an incorrect value.                                    |
|  | Note: These bits are not used in $I^2S$ mode.                 |

# 16.4.8 SPI\_I2S Configuration Register (SPI\_I2SCTRL)

Address offset: 0x1C

| Bit       | Name        | Туре | Description                                                                                                                                                                                 |
|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:12 | -           | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                     |
| Bit 11    | I2SSEL      | rw   | I <sup>2</sup> S mode selection<br>0: SPI mode is selected.<br>1: I <sup>2</sup> S mode is selected.<br>Note: This bit can be configured only after SPI or I <sup>2</sup> S is<br>disabled. |
| Bit 10    | I2SEN       | rw   | I <sup>2</sup> S enable<br>0: I <sup>2</sup> S is disabled.<br>1: I <sup>2</sup> S is enabled.<br>Note: This bit is not used in SPI mode.                                                   |
| Bit 9:8   | I2SMOD[1:0] | rw   | I <sup>2</sup> S configuration mode<br>00: Slave transmission<br>01: Slave reception<br>10: Master transmission                                                                             |



|         |            |    | 11: Master reception                                                             |
|---------|------------|----|----------------------------------------------------------------------------------|
|         |            |    | Note: This bit can be configured only when $I^2S$ is disabled.                   |
|         |            |    | This bit is not used in SPI mode.                                                |
|         |            |    | PCM frame synchronization                                                        |
|         |            |    | 0: Short frame synchronization                                                   |
| Bit 7   | PCMSYNCSEL | rw | 1: Long frame synchronization                                                    |
|         |            |    | Note: This bit is meaningful only when I2SAP = 11 (PCM                           |
|         |            |    | standard is used). This bit is not used in SPI mode.                             |
| Bit 6   | -          | -  | Reserved. Forced to be '0' by hardware.                                          |
|         |            |    | I <sup>2</sup> S standard selection                                              |
|         |            |    | 00: I <sup>2</sup> S Philips standard                                            |
|         |            |    | 01: MSB-justified standard (Left-justified)                                      |
|         |            |    | 10: LSB-justified standard (Right-justified)                                     |
| Bit 5:4 | I2SAP[1:0] | rw | 11: PCM standard                                                                 |
|         |            |    | For more details about I <sup>2</sup> S standard, please refer to <u>Section</u> |
|         |            |    | <u>16.3.2.2</u> .                                                                |
|         |            |    | Note: For correct operation, this bit can be configured only                     |
|         |            |    | when $I^2S$ is disabled. This bit is not used in SPI mode.                       |
|         |            | rw | Steady state clock polarity                                                      |
|         |            |    | 0: I <sup>2</sup> S clock steady state is low level.                             |
| Bit 3   | CPOL       |    | 1: I <sup>2</sup> S clock steady state is high level.                            |
|         |            |    | Note: For correct operation, this bit can be configured only                     |
|         |            |    | when $I^2S$ is disabled. This bit is not used in SPI mode.                       |
|         |            |    | Data length to be transferred                                                    |
|         |            |    | 00: 16-bit data length                                                           |
|         |            |    | 01: 24-bit data length                                                           |
| Bit 2:1 | DLEN[1:0]  | rw | 10: 32-bit data length                                                           |
|         |            |    | 11: Not allowed                                                                  |
|         |            |    | Note: For correct operation, this bit can be configured only                     |
|         |            |    | when $I^2S$ is disabled. This bit is not used in SPI mode.                       |



|       |       |    | Channel length (Number of bits per audio channel)               |
|-------|-------|----|-----------------------------------------------------------------|
|       |       |    | 0: 16-bit wide                                                  |
|       |       |    | 1: 32-bit wide                                                  |
| Bit 0 | CHLEN | rw | Write operation to this bit is meaningful only if $DLEN = 00$ ; |
|       |       |    | otherwise, the channel length is fixed to 32-bit by hardware.   |
|       |       |    | Note: For correct operation, this bit can be configured only    |
|       |       |    | when $I^2S$ is disabled. This bit is not used in SPI mode.      |

# 16.4.9 SPI\_I2S Prescaler Register (SPI\_I2SCLKP)

#### Address offset: 0x20

| Bit       | Name        | Туре | Description                                                                                                        |  |  |  |  |  |  |
|-----------|-------------|------|--------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Bit 15:12 | -           | -    | Reserved. Forced to be '0' by hardware.                                                                            |  |  |  |  |  |  |
| Bit 11:10 | I2SDIV[9:8] | rw   | I <sup>2</sup> S linear prescaler<br>Please refer to the description of I2SDIV[7:0].<br>Master clock output enable |  |  |  |  |  |  |
|           |             |      | Please refer to the description of I2SDIV[7:0].                                                                    |  |  |  |  |  |  |
| Bit 9     | I2SMCLKOE   | rw   | Master clock output enable                                                                                         |  |  |  |  |  |  |
|           |             |      | 0: Master clock output is disabled.                                                                                |  |  |  |  |  |  |
|           |             |      | 1: Master clock output is enabled.                                                                                 |  |  |  |  |  |  |
|           |             |      | Note: For correct operation, this bit can be configured only                                                       |  |  |  |  |  |  |
|           |             |      | when $I^2S$ is disabled.                                                                                           |  |  |  |  |  |  |
|           |             |      | It is only used in $I^2S$ master mode.                                                                             |  |  |  |  |  |  |
|           |             |      | This bit is not used in SPI mode.                                                                                  |  |  |  |  |  |  |
| Bit 8     | I2SODD      | rw   | Odd factor for the prescaler                                                                                       |  |  |  |  |  |  |
|           |             |      | 0: Actual divider factor = I2SDIV*2                                                                                |  |  |  |  |  |  |
|           |             |      | 1: Actual divider factor = $(I2SDIV*2) + 1$                                                                        |  |  |  |  |  |  |
|           |             |      | Please refer to Section 16.3.2.3.                                                                                  |  |  |  |  |  |  |
|           |             |      | Note: For correct operation, this bit can be configured only                                                       |  |  |  |  |  |  |
|           |             |      | when $I^2S$ is disabled. It is only used in $I^2S$ master mode.                                                    |  |  |  |  |  |  |
|           |             |      | This bit is not used in SPI mode.                                                                                  |  |  |  |  |  |  |



| Bit 7:0 | I2SDIV[7:0] | rw | I <sup>2</sup> S linear prescaler I2SDIV[9:8] is configured in Bit 12:11. |
|---------|-------------|----|---------------------------------------------------------------------------|
|         |             |    | It is not allowed to configure $I2SDIV[9:0] = 0$ or                       |
|         |             |    | I2SDIV[9:0] = 1 Please refer to Section $16.3.2.3$ .                      |
|         |             |    | Note: For correct operation, this bit can be configured only              |
|         |             |    | when $I^2S$ is disabled. It is only used in $I^2S$ master mode.           |
|         |             |    | This bit is not used in SPI mode.                                         |

# **17 CAN Bus Controller**

# **17.1 Introduction**

bxCAN is the abbreviation of Basic Extended CAN. It supports the CAN protocols version 2.0A and 2.0B. It is designed to manage a large quantity of incoming messages efficiently with a minimum CPU load. It also meets the priority requirements for message transmissions (The priority is software configurable).

For safety-critical applications, bxCAN provides all hardware functions needed to support Time-Triggered Communication option.

# 17.2 Main Features

- Supports CAN protocol version 2.0A and 2.0B active mode
- Baud rate up to 1 Mbit/s
- Supports time-triggered communication

# 17.2.1 Transmission

- Three transmit mailboxes
- Software configurable transmit priority
- Time stamp on SOF transmission

# 17.2.2 Reception

- 2 receive FIFO with 3-level depth
- Scalable filter banks:
  - 14 filter banks
- Identifier list
- Configurable FIFO overrun handling
- Time stamp on SOF reception



# 17.2.3 Time-triggered communication mode

- Disable automatic retransmission
- 16-bit free running timer
- Time stamp sent in last two data bytes

# 17.2.4 Management

- Maskable interrupts
- Software-efficient mailbox mapping at a unique address space

## 17.2.5 CAN SRAM Memory

• CAN manages the 512-byte SRAM memory.

# **17.3 Function Overview**

# **17.3.1 CAN Overall Function Description**

In current CAN applications, the number of nodes in a CAN network is increasing, and several networks are often linked together via gateways. Therefore, the number of messages (handled by each node) in the system has significantly increased. In addition to the application messages, Network Management and Diagnostic messages are also introduced.

• An enhanced filtering mechanism is required to handle different types of messages.

In addition, since application tasks take more CPU time, real-time constraints caused by message reception should be reduced.

• A receive FIFO scheme allows the CPU to be dedicated to application tasks for a long period of time without losing messages.

The Higher Layer Protocol based on standard CAN drivers requires an efficient interface to the CAN controller.

Figure 17-1 CAN Network Topology





bxCAN module can completely transmit and receive CAN messages automatically; it fully supports standard identifiers (11-bit) and extended identifiers (29-bit).

The application can use these registers to:

- Configure CAN parameters, e.g. baud rate
- Request transmissions
- Handle receptions
- Manage interrupts
- Get diagnostic information

Three transmit mailboxes are provided to the software for sending messages. The transmission scheduler decides messages in which mailbox are to be transmitted first.

bxCAN provides 14 scalable/configurable identifier filter banks, which are programmed by software to select the messages needed and discard the others.

#### **Receive FIFO**

There are two receive FIFOs, and each can store three complete messages. The FIFOs are managed completely by hardware.

Figure 17-2 CAN Block Diagram





# 17.3.2 Operating Mode

bxCAN has three main operating modes: Initialization, Normal, and Sleep. After hardware reset, bxCAN is in Sleep mode to reduce power consumption, and an internal pullup is activated on the CANTX pin. The software requests bxCAN to enter Initialization or Sleep mode by setting the INRQ or SLP bit in the CAN\_MCTRL register. Once entering Initialization mode or Sleep mode, bxCAN confirms by setting the IAK or SAK bits in the CAN\_MSTS register, and the internal pull-up is disabled. When both IAK and SAK are '0', bxCAN is in Normal mode. Before entering Normal mode, bxCAN always has to be synchronized with the CAN bus. To synchronize, bxCAN waits until the CAN bus is idle, which means that 11 consecutive recessive bits are monitored on CANRX.

## 17.3.2.1 Initialization Mode

The software initialization should be done while the hardware is in Initialization mode. To enter this mode, set the INRQ bit in the CAN\_MCTRL register, and then wait until the hardware confirms the request by setting the IAK bit in the CAN\_MSTS register. To leave initialization mode, clear the INRQ bit in the CAN\_MCTRL register. bxCAN will leave Initialization mode once the IAK bit is cleared by hardware.

While bxCAN is in Initialization mode, all message transfers are stopped, and the CANTX pin outputsrecessive bits (high level). Entering Initialization mode does not change any of the configuration registers.Hangzhou Vango Technologies, Inc.637 / 782

To initialize bxCAN, software has to include the bit timing (CAN\_BTMG) and control (CAN\_MCTRL) registers. Before initializing bxCAN filter banks (mode, scale, FIFO assignment, activation, and filter values), software has to set the FINT bit in the CAN\_FM register. Filter initialization can be done outside the Initialization mode.

Note: When FINT = 1, message reception is disabled.

The filter value can be modified by clearing the filter activation bits (in the CAN\_FA1 register). If filter banks are not used, they should be kept in deactivation (Keep the FEN bit cleared).

#### 17.3.2.2 Normal Mode

Once the initialization is completed, the software must request the hardware to enter Normal mode to start regular reception and transmission. The request to enter Normal mode is issued by software, clearing the INRQ bit in the CAN\_MCTRL register, and then wait until the hardware sets the IAK bit in the CAN\_MSTS register to confirm. The bxCAN enters Normal mode and is ready to transmit and receive messages when it is synchronized with the CAN bus, which means a sequence of 11 consecutive recessive bits (Bus Idle state) on the CANRX pin is detected.

There is no need to set the filter values in Initialization mode, but it must be done while the filter is not active (the corresponding FEN bit cleared). The filter scale and mode configuration must be done before entering Normal mode from Initialization mode.

#### 17.3.2.3 Sleep Mode (Low Power)

bxCAN can work in low-power mode, Sleep mode. To enter this mode, software makes request by setting the SLP bit in the CAN\_MCTRL register. In this mode, the bxCAN clock is stopped, but software can still access the bxCAN mailboxes.

When bxCAN is in Sleep mode, software can request to enter Initialization mode by setting the INRQ bit in the CAN\_MCTRL register, and at the same time clears the SLP bit.

There are two ways to wake up bxCAN (exit Sleep mode): Clearing the SLP bit with software or detection of CAN bus activity through hardware.

On CAN bus activity detection, hardware automatically performs the wakeup sequence by clearing the SLP bit if the AWU bit in the CAN\_MCTRL register is set. If the AWU bit is cleared in the CAN\_MCTRL register, software has to clear the SLP bit when a wakeup interrupt occurs to exit from Sleep mode.

Note: If wakeup interrupt is enabled (the WKIE bit set in the CAN\_INTEN register), a wakeupHangzhou Vango Technologies, Inc.638 / 782

interrupt will be generated on detection of CAN bus activity, no matter whether hardware automatically wakes up bxCAN or not.

After the SLP bit is cleared, the exit from Sleep mode must be synchronized with the CAN bus, please refer to Figure 17-3. The exit from Sleep mode is confirmed once the SAK bit is cleared by hardware.

Figure 17-3 bxCAN Operating Mode



*Note:* 1. ACK = The state during which hardware confirms Sleep or Initialization mode request and sets the IAK or SAK bits in the CAN\_MSTS register

2. SYNC = The state during which bxCAN waits until the CAN bus is idle, which means that 11 consecutive recessive bits are monitored on CANRX.

# 17.3.3 Test Mode

Test modes can be selected by the SIL and/or LBK bits in the CAN\_BTMG register. These two bits must be configured in Initialization mode. Once Test mode is selected, the INRQ bit in the CAN\_MCTRL register must be reset to successfully enter Test mode.

## 17.3.3.1 Silent Mode

Silent mode is selected by setting the SIL bit in the CAN\_BTMG register. In Silent mode, bxCAN can receive valid data frames and valid remote frames, but it sends only recessive bits and cannot successfully start message transmission. If the bxCAN has to send a dominant bit (ACK bit, overload flag,



and active error flag), this dominant bit is rerouted internally so that the CAN core can monitor it. At the same time, the CAN bus is not affected and still remains in recessive state. Therefore, Silent mode is usually used to analyze the traffic on a CAN bus without affecting it: Dominant bits (acknowledge bits and error frames) will not be transmitted to the bus.

Figure 17-4 bxCAN in Silent Mode



## 17.3.3.2 Loopback Mode

Loopback mode can be selected by setting the LBK bit in the CAN\_BTMG register. In Loopback mode, bxCAN stores its own transmitted messages as received messages (if they pass acceptance filtering) in a receive mailbox.

Figure 17-5 bxCAN in Loopback Mode





Loopback mode can be used for self-test functions. To be independent of external events, the CAN core ignores acknowledge errors (no dominant bit sampled in the acknowledge slot of a data/remote frame) in Loopback mode. In this mode, bxCAN performs an internal feedback from its Tx output to its Rx input and disregards the actual value of the CANRX pin. The transmitted messages can be monitored on the CANTX pin.

# 17.3.3.3 Loopback and Silent Mode

Figure 17-6 bxCAN in Loopback and Silent Mode



It is also possible to combine Loopback mode and Silent mode by setting both the LBK and SIL bits in the CAN\_BTMG register. This mode can be used for a "Hot Self-test", which means that the bxCAN can be tested like in Loopback mode but without affecting the whole CAN system connected to the CANTX and CANRX pins. In this mode, the CANRX pin is disconnected from the CAN bus, and the CANTX pin is held recessive.

# 17.3.4 V84XXX in Debug Mode

When the microcontroller enters debug mode, Cortex<sup>®</sup>-M4 core halted, the bxCAN continues to work normally or stops, depending on the configuration of the following bits:

- The DBG\_CAN1\_STOP bit of CAN1 in debug module (DBG)
- The DBF bit in CAN\_MCTRL



# **17.3.5 Transmission Handling**

Message transmission process is as follows: The application selects one empty transmit mailbox; then, it configures the identifier, the data length, and the data to be transmitted; finally, it sets the TRQ bit in the CAN\_TMIx register to make transmission request. Once the TRQ bit is set, the mailbox is not empty anymore, and software no longer has write access to the mailbox registers. Immediately after the TRQ bit is set, the mailbox enters pending state and waits to become the highest priority mailbox (Please refer to "Transmit Priority.") As soon as the mailbox becomes the top priority, it will be scheduled for transmission. The message transmission of the scheduled mailbox will start (enter transmit state) right after the CAN bus becomes idle. Once the messages in the mailbox are successfully transmitted, it becomes empty again. The hardware then indicates a successful transmission by setting the RQC and TOK bits in the CAN\_TSTS register accordingly.

If the transmission fails, setting the ALS bit in the CAN\_TSTS register indicates an arbitration lost, and setting the TER bit indicates transmission error.

## 17.3.5.1 Transmit priority

#### 1. Determined by identifier

When more than one transmit mailbox is pending, the transmission priority is given by the identifier of the message in the mailbox. The message with the lowest identifier value has the highest priority according to the arbitration of the CAN protocol. If the identifier values are equal, mailbox with the lower number will be scheduled first.

2. Determined by transmit request order

The transmit mailboxes can be configured as transmit FIFO by setting the TFP bit in the CAN\_MCTRL register. In this mode, the priority order is given by the transmit request order. This mode is very useful for segmented transmission.

#### 17.3.5.2 Abort

A transmission request can be aborted by setting the ARQ bit in the CAN\_TSTS register. If the mailbox is in pending or scheduled state, transmit request is aborted immediately. An abort request while the mailbox is in transmit state can cause two results. If the messages in the mailbox is transmitted successfully, the mailbox becomes empty with the TOK bit set in the CAN\_TSTS register. If the



transmission fails, the mailbox becomes scheduled, the transmission is aborted, and the mailbox becomes empty with TOK cleared by hardware. Therefore, if the mailbox is in transmission, it will become empty after the current transmission is completed.

## 17.3.5.3 Non-automatic retransmission mode

This mode is implemented to fulfil the requirement of time-triggered communication option in the CAN standard. To configure the hardware in this mode, the NART bit in the CAN\_MCTRL register must be set. In this mode, each transmission is performed only once. If the first attempt fails due to an arbitration loss or an error, the hardware will not automatically restart the message transmission.

At the end of a transmission, the hardware considers the request completed and sets the RQC bit in the CAN\_TSTS register. The result of the transmission is indicated by the TOK, ALS, and TER bits.



Figure 17-7 Transmit Mailbox States

# **17.3.6 Time-triggered Communication Mode**

In this mode, the internal timer of the CAN hardware is activated and used to generate the time stamps (for Tx and Rx mailboxes), which are stored in the CAN\_RDTx/ CAN\_TDTx registers, respectively. The



internal timer is incremented each CAN bit time. The internal timer is captured on the sample point of the start of frame bit in both reception and transmission, generating time stamps.

# 17.3.7 Reception Handling

The received messages are stored in FIFO with three-level mailbox depth. In order to save CPU load, simplify the software, and ensure data consistency, the FIFO is completely managed by hardware. The application accesses the messages received first in the FIFO only through the FIFO output mailbox.

# 17.3.7.1 Valid message

A received message is considered valid when it is received correctly according to the CAN protocol (no error until the last bit of the EOF field), and it passes through the identifier filtering successfully.

Figure 17-8 Receive FIFO States





#### 17.3.7.2 FIFO management

Starting from the empty state, FIFO becomes pending\_1 after the first valid message is received. The hardware configures RFP[1:0] in the CAN\_RF register as '01' (binary 01b). The software can read the FIFO output mailbox to obtain the messages, and release the mailbox by setting the RRFM bit in the CAN\_RF register. Then, the FIFO becomes empty again. If a new valid message is received in the meantime, the FIFO stays in pending\_1 state, and software can read the FIFO output mailbox to obtain new messages.

If the application does not release the mailbox, FIFO enters pending\_2 state after receiving the next



valid message. Hardware configures RFP[1:0] as '10' (binary 10b). The above storage process is repeated for the third valid message, which puts the FIFO into pending\_3 state (RFP[1:0] = 11b). At this point, the software must release the mailbox by setting the RRFM bit, so that FIFO has enough room to store the next valid message. Otherwise, the next valid message received will cause a loss of message.

## 17.3.7.3 Overrun

When the FIFO is in pending\_3 state (i.e. the three mailboxes are full), the next valid message reception will lead to an overrun, and a message will be lost. In this case, the hardware sets the RFOV bit in the CAN\_RF register to indicate the overrun. Which message is lost depends on the configuration of the FIFO:

• If the FIFO lock function is disabled (the RFL bit in the CAN\_MCTRL register is cleared), the last message received in the FIFO will be overwritten by the new incoming message. In this way, the latest messages will not be lost.

• If the FIFO lock function is enabled (the RFL bit in the CAN\_MCTRL register is set), the latest message will be discarded, and the software will read three oldest messages in the FIFO.

## 17.3.7.4 Reception-related interrupts

Once a message is stored in the FIFO, the RFP[1:0] bits are updated by hardware, and an interrupt request is generated if the RFPIE bit in the CAN\_INTEN register is set.

When the FIFO becomes full (i.e. the third message is stored), the RFFU bit in the CAN\_RF register is set, and a FULL interrupt is generated if the RFFUIE bit in the CAN\_INTEN register is set. In addition, an overrun interrupt is generated if the RFOVIE bit in the CAN\_INTEN register is set.

# **17.3.8 Identifier Filtering**

In the CAN protocol, the identifier of a message is not associated with the address of a node, but related to the content of the message. Consequently, a transmitter broadcasts its message to all receivers. On message reception, a receiver node decides (depending on the identifier value) whether the software needs the message or not. If the message is needed, it is copied into the SRAM; if not, the message is discarded without intervention by the software.

To fulfill this requirement, the bxCAN controller provides 14 configurable and scalable filter banks ( $13 \sim 0$ ) to receive only the messages that the software needs. This hardware filtering saves CPU resources which would be otherwise taken to perform filtering by software. Each filter bank x consists of two 32-bit



registers, CAN\_FBxR1 and CAN\_FBxR2.

#### 17.3.8.1 Scalable width

The width of each filter bank can be scaled independently to fulfill the different needs of applications. According to the different filter scales, each filter bank can provide:

• One 32-bit filter, including: the SID[10:0], EID[17:0], IDT, and RTR bits

• Two16-bit filters, including: the SID[10:0], IDT, RTR, and EID[17:15] bits Furthermore, the filters can be configured in mask mode or in identifier list mode.

#### 17.3.8.2 Mask mode

In mask mode, the identifier registers, together with mask registers, specifies which bits of the identifier are handled as "must match" or as "don't care".

## 17.3.8.3 Identifier list mode

In identifier list mode, the mask registers are used as identifier registers. Thus, instead of defining an identifier register and a mask register, two identifier registers are adopted. Each bit of the Rx message identifier should match the filter identifier.

#### 17.3.8.4 Filter bank scale and mode configuration

The filter banks are configured through the corresponding CAN\_FM register. Before configuring a filter bank, it must be deactivated by clearing the FEN bit in the CAN\_FA1 register. The filter scale is configured through the corresponding FBSx bit in the CAN\_FS1 register. The identifier list or identifier mask mode for the corresponding mask/identifier registers is configured through the FMSx bit in the CAN\_FM1 register.

To filter a group of identifiers, configure the filter bank to work in mask mode. To select a single identifier, configure the filter bank to work in identifier list mode.

Filter banks not used by the application should be left deactivated.

Each filter within a filter bank is numbered (the Filter Number), from 0 to a maximum value, which depends on the mode and the scale configured in each filter bank.

For the filter configuration, please refer to Figure 17-9.

Figure 17-9 Filter Bank Scale Configuration - Register Organization



Hangzhou Vango Technologies, Inc.

|                                        |                 | One 32-bit fil | ter—Identifier mas    | k            |                        |                                                                                       |          |           |          | Filter<br>number |
|----------------------------------------|-----------------|----------------|-----------------------|--------------|------------------------|---------------------------------------------------------------------------------------|----------|-----------|----------|------------------|
|                                        | 0               | D              | CAN_FBxR1[31:24]      | CAN_FB       | R1[23:16]              | CAN_FBxR1[15:8]                                                                       | CAN_FB   | xR1[7:0]  |          |                  |
|                                        | FMSx            | Mask           | CAN_FBxR2[31:24]      | CAN_FB       | R2[23:16]              | CAN_FBxR2[15:8]                                                                       | CAN_FB   | xR2[7:0]  | }        | n                |
| ÷                                      | Ē               | Mapping        | SED(10:3)             | 90(2:0)      | EID[17:13]             | 00(12-5)                                                                              | EID[4:0] | IDT RTR 0 | J        |                  |
| FBSx =                                 | Ē               | Two 32-bit fi  | lter—Identifier list  |              |                        |                                                                                       |          |           |          |                  |
|                                        | =               | D              | CAN_FBxR1[31:24]      | CAN_FB       | R1[23:16]              | CAN_FBxR1[15:8]                                                                       | CAN_FB   | xR1[7:0]  |          | n                |
|                                        | FMSX            | D              | CAN_FBxR2[31:24]      | CAN_FB       | R2[23:16]              | CAN_FBxR2[15:8]                                                                       | CAN_FB   | xR2[7:0]  |          |                  |
|                                        | Ľ               | Mapping        | SED(10:3)             | 90(2:0)      | EID[17:13]             | 00(12-5)                                                                              | EID[4:0] | IDT RTR 0 |          | n + 1            |
|                                        |                 | Two 16-bit fi  | ter—Idetntifier ma    | isk          |                        |                                                                                       |          |           |          |                  |
|                                        |                 | D              | CAN_FBxR1[15:8]       | CAN_FE       | 3xR1[7:0]              |                                                                                       |          |           | Ŋ        | n                |
|                                        | 0=              | Mask           | CAN_FBxR1[31:24]      | CAN_FB       | R1[23:16]              |                                                                                       |          |           |          | n                |
|                                        | FMSX            | ID             | CAN_FBxR2[15:8]       | CAN_FE       | 3xR2[7:0]              |                                                                                       |          |           | <u>ה</u> |                  |
|                                        |                 | Mask           | CAN_FBxR2[31:24]      | CAN_FB       | R2[23:16]              |                                                                                       |          |           | Ì.       | n + 1            |
| 0 =                                    |                 | Mapping        | 580(10:3)             | SID(2:0) RTR | IDT EID[17:15]         |                                                                                       |          |           |          |                  |
| FBSX                                   |                 | Four16-bit f   | ilter—Identifier list | :            |                        |                                                                                       |          |           |          |                  |
|                                        |                 | ID             | CAN_FBxR1[15:8]       |              | 3xR1[7:0]              |                                                                                       |          |           |          | n                |
|                                        | = 1             | ID             | CAN_FBxR1[31:24]      | CAN_FB       | R1[23:16]              |                                                                                       |          |           |          | n + 1            |
|                                        | FMSX            | D              | CAN_FBxR2[15:8]       | CAN_FE       | 3xR2[7:0]              |                                                                                       |          |           |          | n + 2            |
|                                        |                 | D              | CAN_FBxR2[31:24]      | CAN_FB       | R2[23:16]              |                                                                                       |          |           |          | n + 3            |
|                                        | ~ ~             | Mapping        | 580(10:3)             | SID[2:0] RTR | IDT [ID[17:15]         |                                                                                       |          |           |          |                  |
| Filter bank scale<br>configuration bit | Filter bank mod |                |                       |              | ID = Iden<br>Note 1: T | bank number<br>tifier<br>'hese bits are in the CAN_FS<br>hese bits are in the CAN_FM: |          |           |          |                  |

## 17.3.8.5 Filter match index

Once a message is received in the FIFO, it can be accessed by the application. Normally, message data is copied into SRAM; to copy the data to the right location, the application has to identify the data according to the identifier. bxCAN provides a filter match index to simplify this identifying process.

This index is stored in the mailbox, together with the message, according to the filter priority rules. Thus, each received message has its associated filter match index.

The filter match index can be used in the following two ways:

- Compare the filter match index with a list of expected values
- Use the filter match index as an index to access the data destination location

For filters in identifier list mode (nonmasked filters), the software no longer has to compare the identifier. For masked filters in mask mode, software only compares those masked bits needed (must match bits).

When numbering filters, activation state of the filter banks is not taken into account. In addition, each



FIFO numbers its own associated filter independently. Please refer to the example shown in Figure 17-10.

Figure 17-10 Example of Filter Numbering



#### 17.3.8.6 Filter priority rules

According to the different filter combinations, it is possible that a single identifier can pass through several filters successfully. In this case, the filter match value stored in the receive mailbox is determined by the following priority rules:

- A 32-bit filter takes priority over a 16-bit filter.
- For filters with equal scale, priority is given to the identifier list mode over the identifier mask mode.
- For filters with equal scale and in the same mode, priority is given according to the filter number (the lower the number, the higher the priority).



Figure 17-11 Example of Filtering Mechanism



The example above shows the filtering principle of the bxCAN: On reception of a message, its identifier is first compared with the filters configured in identifier list mode. If there is a match, the message is stored in the associated FIFO, and the index of the matched filter is stored in the filter match Index. As shown in the example, the identifier matches with Identifier #4, so the message content and FID4 are stored in the FIFO.

If there is no match, the identifier is then compared with the filters configured in mask mode. If the identifier does not match any of the identifiers configured in the filters, the message is discarded by hardware without disturbing the software.



#### 17.3.9 Message Storage

Mailboxes are the interface between the software and the hardware for messages transfers. A mailbox contains all information related to a message: identifier, data, control, status, and time stamp information.

#### 17.3.9.1 Transmit mailbox

The software should set up the message to be transmitted in an empty transmit mailbox (and then sends transmit requests). The status of the transmission is indicated in the CAN\_TSTS register.

Table 17-1 Transmit Mailbox Mapping

| Offset to Transmit Mailbox Base Address | Register Name |
|-----------------------------------------|---------------|
| 0                                       | CAN_TMIx      |
| 4                                       | CAN_TDTx      |
| 8                                       | CAN_TDLx      |
| 12                                      | CAN_TDHx      |

#### 17.3.9.2 Receive mailbox (FIFO)

When a message is received, the software can access the FIFO output mailbox to read it. Once the software handles the message (e.g. read it), the software must release the message by setting the RRFM bit in the CAN\_RFx register to make rooms to store the following received message. The filter match index is stored in the FID field of the CAN\_RDTx register. The 16-bit time stamp value is stored in the TS[15:0] field of CAN\_RDTx.

Table 17-2 Receive Mailbox Mapping

| Offset to Receive Mailbox Base Address | Register Name |
|----------------------------------------|---------------|
| 0                                      | CAN_RFIx      |
| 4                                      | CAN_RDTx      |
| 8                                      | CAN_RDLx      |
| 12                                     | CAN_RDHx      |

Figure 17-12 CAN Error State Diagram





#### 17.3.10 Error Management

The error management as described in the CAN protocol is handled entirely by hardware with a Transmit Error Counter (the TEC field in the CAN\_ESTS register) and a Receive Error Counter (the REC field in the CAN\_ESR register). Its value is incremented or decremented according to the error. For detailed information about TEC and REC management, please refer to the CAN standard.

The value of both of the counter may be read by software to determine the stability of the CAN network.

Furthermore, the CAN\_ESTS register provides detailed information of the current error status. By configuring the CAN\_INTEN register (e.g. the ERIE bit.), the software can control the interrupt generation on error detection in a flexible way.

#### 17.3.10.1 Bus-off recovery

bxCAN enters bus-off state when TEC is greater than 255, and at the same time the BFF bit is set in the CAN\_ESTS register. In bus-off state, bxCAN is unable to transmit and receive messages.

According to the configuration of ABO bit in the CAN\_MCTRL register, bxCAN will recover from bus-off (become error active again) either automatically or on software request. But in both cases, the bxCAN has to wait for a recovery sequence specified in the CAN standard (128 occurrences of 11 consecutive recessive bits monitored on the CANRX pin).

If ABO is set, bxCAN will start the recovering sequence automatically after it enters bus-off state.



If ABO is cleared, the software must first request bxCAN to enter and then to leave Initialization mode before initiating the recovering sequence.

Note: In Initialization mode, bxCAN does not monitor the CANRX signal, so it cannot complete the recovery sequence. To recover, bxCAN must be working in Normal mode.

#### 17.3.11 Bit Timing

The bit timing logic monitors the serial CAN bus through sampling, and adjust its sampling point by synchronizing with the start-bit edge and resynchronizing with the following edges.

Its operation can be briefly introduced as splitting every nominal bit time into three segments as follows:

• Synchronization segment (SYNC\_SEG): Usually a bit change is expected to occur within this time segment. It has a fixed length of one time quantum (1 x tCAN).

• Bit segment 1 (BS1): This segment defines the location of the sample point. It includes the PROP\_SEG and PHASE\_SEG1 of the CAN standard. Its duration is programmable between 1 and 16 time quanta but may be automatically lengthened to compensate for positive phase drifts caused by different frequencies of various nodes in the network.

• Bit segment 2 (BS2): This segment defines the location of the transmit point. It represents the PHASE\_SEG2 of the CAN standard. Its duration is programmable between 1 and 8 time quanta but may also be automatically shortened to compensate for negative phase drifts.

The re-Synchronization Jump Width (SJW) defines an upper bound to the amount of lengthening or shortening of the bit segments. It is programmable between 1 and 4 time quanta.

A valid edge is defined during the first transition from a dominant bit to a recessive bit when bxCAN itself does not send a recessive bit. If a valid edge is detected in BS1 instead of SYNC\_SEG, BS1 is extended up to SJW, so the sample point will be delayed.

On the contrary, if a valid edge is detected in BS2 instead of SYNC\_SEG, BS2 is shortened up to SJW, so the transmit point is moved earlier.

To avoid programming errors, the configuration of the bit timing register (CAN\_BTMG) is only possible when bxCAN is in Initialization state.

*Note: For the detailed descriptions of the CAN bit timing and resynchronization* mechanism, please refer to the ISO 11898 standard.



#### Figure 17-13 Bit Timing



Figure 17-14 Various CAN Frames





#### 17.3.12 bxCAN Interrupt

Four interrupt vectors are dedicated to bxCAN. Each interrupt source can be independently enabled or

disabled by the CAN interrupt enable register (CAN\_INTEN).







- Transmit interrupts can be generated by the following events:
  - Transmit mailbox 0 becomes empty, and the RQC0 bit in the CAN\_TSTS register is set.
  - Transmit mailbox 1 becomes empty, and the RQC1 bit in the CAN\_TSTS register is set.
  - Transmit mailbox 2 becomes empty, and the RQC2 bit in the CAN\_TSTS register is set.
- FIFO0 interrupts can be generated by the following events:
  - FIFO0 receives a new message, the RFP0 bit in the CAN\_RF0 register is not '00' anymore.
  - FIFO0 full condition, in which the RFFU0 bit in the CAN\_RF0 register is set.
  - FIFO0 overrun condition, in which the RFOV0 bit in the CAN\_RF0 register is set
- FIFO1 interrupts can be generated by the following events:
- FIFO1 receives a new message, the RFP1 bit in the CAN\_RF1 register is not '00' anymore.
- FIFO1 full condition, in which the RFFU1 bit in the CAN\_RF1 register is set.
- FIFO1 overrun condition, in which the RFOV1 bit in the CAN\_RF1 register is set
- Error and status change interrupts can be generated by the following events:

 Error condition; Please refer to "CAN Error Status Register (CAN\_ESTS)" for more details about error conditions.

- Wakeup condition; The start of frame bit (SOF) is monitored on the CAN Rx pin.

- CAN enters Sleep mode.

## **17.4 CAN Registers**

#### **17.4.1 Register Access Protection**

Erroneous access to certain registers can cause a CAN note's temporarily disturbance to the whole CAN network. Therefore, the CAN\_BTMG register can be modified by software only while the CAN is in Initialization mode.

Although the transmission of incorrect data will not cause problems at the CAN network level, it can severely disturb the application. Hence, a transmit mailbox can be modified by software only while it is in empty state.

The filter values can be modified only when the associated filter banks are deactivated or after setting the FINIT bit. Moreover, the modification of the filter configuration (that is, to modify the CAN\_FM1, CAN\_FS1, and CAN\_FFA1 registers) can only be done when the filter initialization mode is set (FINT = 1).

#### **17.4.2 CAN Control and Status Register**

#### 17.4.2.1 CAN Main Control Register (CAN\_MCTRL)

Address offset: 0x00

Reset value: 0x0001 0002

| Bit        | Name | Туре                                                  | Description                                                |
|------------|------|-------------------------------------------------------|------------------------------------------------------------|
| Bit 31:17  | -    | -                                                     | Reserved. Forced to be '0' by hardware.                    |
|            |      | Debug freeze                                          |                                                            |
|            | 225  |                                                       | 0: CAN works normally during debug.                        |
| Bit 16 DBF | rw   | 1: CAN reception/transmission is frozen during debug. |                                                            |
|            |      |                                                       | Reception FIFOs can still be accessed/controlled normally. |



|          |      |    | bxCAN software reset                                             |
|----------|------|----|------------------------------------------------------------------|
|          |      |    | 0: This peripheral is in normal operation.                       |
| Bit 15   | RST  | rw | 1: bxCAN is forced to reset. After reset, it enters Sleep mode   |
|          |      |    | (the FMP bit and the CAN_MCTRL register are initialized to their |
|          |      |    | reset values). Then, this bit is cleared by hardware             |
|          |      |    | automatically.                                                   |
| Bit 14:8 | -    | -  | Reserved. Forced to be '0' by hardware.                          |
|          |      |    | Time-triggered communication mode                                |
| Bit 7    | ттс  | rw | 0: Time-triggered communication mode is disabled.                |
|          |      |    | 1: Time-triggered communication mode is enabled.                 |
|          |      |    | Automatic bus-off management                                     |
|          |      |    | This bit determines the conditions under which the CAN           |
|          |      |    | hardware exits the bus-off state.                                |
|          |      |    | 0: Software makes requests to leave bus-off state. First, the    |
| Bit 6    | ABO  | rw | software sets and clears the INRQ bit of the CAN_MCTRL           |
|          |      |    | register. Once 128 occurrences of 11 recessive bits are          |
|          |      |    | monitored, it leaves bus-off state.                              |
|          |      |    | 1: Hardware automatically leaves bus-off state once 128          |
|          |      |    | occurrences of 11 recessive bits are monitored.                  |
|          |      |    |                                                                  |
|          |      |    | Automatic wakeup mode                                            |
|          |      |    | This bit determines whether hardware or software wakes up        |
|          |      |    | CAN from Sleep mode.                                             |
|          |      |    | 0: Software wakeup. Leaving Sleep mode after the software        |
| Bit 5    | AWU  | rw | cleans the SLP bit in the CAN_MCTRL register.                    |
|          |      |    | 1: Hardware automatic wakeup. Leaving Sleep mode once the        |
|          |      |    | hardware detects CAN message. During wakeup, hardware            |
|          |      |    | automatically clears the SLP and SAK bits in the CAN_MSTS        |
|          |      |    | register.                                                        |
|          |      |    | No automatic retransmission                                      |
| Bit 4    | NART | rw | 0: According to the CAN standard, when CAN hardware fails to     |
|          |      |    | transmit messages, it will automatically retransmit the message  |
|          |      |    |                                                                  |



|       |      |    | until it succeeds.                                               |
|-------|------|----|------------------------------------------------------------------|
|       |      |    | 1: CAN message will be transmitted only once, regardless of the  |
|       |      |    | transmission result (success, error, or arbitration lost).       |
|       |      |    | Receive FIFO locked mode                                         |
|       |      |    | 0: Receive FIFO is not locked on overrun. Once a received FIFO   |
|       |      |    | message is not read, the next incoming message will overwrite    |
| Bit 3 | RFL  | rw | the previous one.                                                |
|       |      |    | 1: Receive FIFO is locked against overrun. Once a received FIFO  |
|       |      |    | message is not read, the next incoming message will be           |
|       |      |    | discarded.                                                       |
|       |      |    | Transmit FIFO priority                                           |
|       |      |    | This bit controls the transmission priority when several         |
| Bit 2 | TFP  | rw | mailboxes are pending at the same time.                          |
|       |      |    | 0: Priority is determined by the identifier of the message.      |
|       |      |    | 1: Priority is determined by the request order.                  |
|       |      |    | Sleep mode request                                               |
|       |      | rw | This bit is set by software to request CAN to enter Sleep mode.  |
|       |      |    | As soon as the current CAN activity (transmission or reception   |
|       |      |    | of messages) is completed, CAN enters Sleep mode.                |
| Bit 1 | SLP  |    | This bit is cleared by software to make CAN exit Sleep mode.     |
|       | SLF  |    |                                                                  |
|       |      |    | This bit is cleared by hardware when the AWU bit is set, and a   |
|       |      |    | SOF bit is detected on the CANRx signal.                         |
|       |      |    | This bit is set after reset; that is, CAN is in Sleep mode after |
|       |      |    | reset.                                                           |
|       |      |    | Initialization request                                           |
|       | INRQ |    | The software clears this bit to switch CAN from Initialization   |
|       |      |    | mode into Normal mode: Once CAN monitors 11 consecutive          |
| Bit 0 |      | rw | recessive bits on the Rx signal, the CAN hardware is             |
|       |      |    | synchronized and ready for transmission and reception. Hence,    |
|       |      |    | hardware signals this event by clearing the IAK bit in the       |
|       |      |    | CAN_MSTS register.                                               |
|       |      |    |                                                                  |



|  | The software sets this bit to request CAN to enter Initialization |
|--|-------------------------------------------------------------------|
|  | mode from Normal mode: Once the current CAN activity              |
|  | (transmission or reception) is completed, CAN enters              |
|  | Initialization mode. Hardware signals this event by setting the   |
|  | IAK bit in the CAN_MSTS register.                                 |

#### 17.4.2.2 CAN Main Status Register (CAN\_MSTS)

Address offset: 0x04

Reset value: 0x0000 0C02

|              |       | _     |                                                                 |
|--------------|-------|-------|-----------------------------------------------------------------|
| Bit          | Name  | Туре  | Description                                                     |
| Bit 31:12    | -     | -     | Reserved. Forced to be '0' by hardware.                         |
| Bit 11       | RXS   | r     | CANRx signal                                                    |
|              |       |       | This bit indicates the actual level of the CAN Rx pin (CAN_RX). |
| Bit 10       | LSAP  | r     | Last sample point                                               |
|              |       |       | Last sample value on the CAN Rx pin (corresponding to current   |
|              |       |       | Rx bit value).                                                  |
| Bit 9        | RX    | r     | Receive mode                                                    |
|              |       |       | When this bit is set, CAN is the current receiver.              |
| Bit 8        | тх    | r     | Transmit mode                                                   |
|              |       |       | When this bit is set, CAN is the current transmitter.           |
| Bit 7:5      | -     | -     | Reserved. Forced to be '0' by hardware.                         |
| Bit 4        | SAKIT | rc_w1 | Sleep acknowledge interrupt                                     |
|              |       |       | When SAKIE = 1, this bit is set by hardware to signal that CAN  |
|              |       |       | enters Sleep mode, and then the corresponding interrupts will   |
|              |       |       | be generated. When set, this bit generates a status change      |
|              |       |       | interrupt if the SAKIE bit in the CAN_INTEN register is set.    |
|              |       |       | This bit is cleared by software, or by hardware when SAK is     |
|              |       |       | cleared.                                                        |
|              |       |       | Note: When SAKIE = 0, no polling on this bit is possible;       |
| <b>AII</b> N |       |       | instead, the SAK bit is polled to learn the Sleep status.       |



| D:1- 2 |      |       |                                                                    |
|--------|------|-------|--------------------------------------------------------------------|
| Bit 3  | WKIT | rc_w1 | Wakeup interrupt                                                   |
|        |      |       | When CAN is in Sleep mode, this bit is set by hardware to signal   |
|        |      |       | that the start of frame bit (SOF) is detected; a status change     |
|        |      |       | interrupt is generated if the WKIE bit in the CAN_INTEN register   |
|        |      |       | is set.                                                            |
|        |      |       | This bit is cleared by software.                                   |
| Bit 2  | ERIT | rc_w1 | Error interrupt                                                    |
|        |      |       | On error detection, certain bits in the CAN_ESTS register are      |
|        |      |       | set; if the corresponding interrupt enable bit in the CAN_INTEN    |
|        |      |       | register is also set, then hardware sets this bit; a status change |
|        |      |       | interrupt is generated if the ERRIE bit in the CAN_INTEN           |
|        |      |       | register is set. This bit is cleared by software.                  |
| Bit 1  | SAK  | r     | Sleep mode acknowledge                                             |
|        |      |       | This bit is set by hardware to indicate that CAN hardware is now   |
|        |      |       | in Sleep mode. This bit acknowledges the Sleep mode request        |
|        |      |       | from the software (set the SLP bit in CAN_MCTRL register).         |
|        |      |       | This bit is cleared by hardware when the CAN hardware exits        |
|        |      |       | Sleep mode (should be synchronized with CAN bus). The              |
|        |      |       | synchronization with CAN bus means that the hardware has to        |
|        |      |       | monitor a sequence of 11 consecutive recessive bits on the CAN     |
|        |      |       | RX signal.                                                         |
|        |      |       | Note: The process of leaving Sleep mode is triggered when the      |
|        |      |       | SLP bit in the CAN_MCTRL register is cleared. For detailed         |
|        |      |       | information about clearing the SLP bit, please refer to the        |
|        |      |       | description of the AWU bit in the CAN_MCTRL register.              |
| Bit 0  | ІАК  | r     | Initialization acknowledge                                         |
|        |      |       | This bit is set by hardware to indicate that the CAN hardware is   |
|        |      |       | now in Initialization mode. This bit acknowledges the              |
|        |      |       | initialization request from the software (should be synchronized   |
|        |      |       | with CAN bus). The synchronization with CAN bus means that         |
|        |      |       | the hardware has to monitor a sequence of 11 consecutive           |



#### 17.4.2.3 CAN Tx Status Register (CAN\_TSTS)

Address offset: 0x08

Reset value: 0x1C00 0000

| Bit    | Name  | Туре | Description                                                                                                                                                                                                                                         |
|--------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31 | LPM2  | r    | Lowest priority flag for mailbox 2<br>This bit is set by hardware when more than one mailbox are<br>pending for transmission, and mailbox 2 has the lowest<br>priority.                                                                             |
| Bit 30 | LPM1  | r    | Lowest priority flag for mailbox 1<br>This bit is set by hardware when more than one mailbox are<br>pending for transmission, and mailbox 1 has the lowest<br>priority.                                                                             |
| Bit 29 | LPM0  | r    | Lowest priority flag for mailbox 0<br>This bit is set by hardware when more than one mailbox are<br>pending for transmission, and mailbox 0 has the lowest<br>priority.<br>Note: The LPM[2:0] bits are cleared when only one mailbox<br>is pending. |
| Bit 28 | TSME2 | r    | Transmit mailbox 2 empty<br>This bit is set by hardware when there is no pending transmit<br>request in mailbox 2.                                                                                                                                  |
| Bit 27 | TSME1 | r    | Transmit mailbox 1 empty<br>This bit is set by hardware when there is no pending transmit<br>request in mailbox 1.                                                                                                                                  |
| Bit 26 | TSME0 | r    | Transmit mailbox 0 empty<br>This bit is set by hardware when there is no pending transmit<br>request in mailbox 0.                                                                                                                                  |



| Bit 25:24<br>Bit 23 | NTM[1:0]<br>ARQ2 | r     | Mailbox code<br>When at least one transmit mailbox is empty, the two bits<br>indicates the number of the next empty transmit mailbox<br>When all transmit mailbox are empty, the two bits indicates<br>the number of the transmit mailbox with the lowest priority.<br>Abort request for mailbox 2<br>Set by software to abort the transmission request of mailbox<br>2. Cleared by hardware when the mailbox 2 becomes empty.<br>Setting this bit has no effect when the mailbox 2 is not |
|---------------------|------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 22:20           | _                | _     | pending for transmission.<br>Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 19              | TER2             | rc_w1 | Transmission error of mailbox 2<br>This bit is set when transmission failure is caused by an error<br>in mailbox 2.                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 18              | ALS2             | rc_w1 | Arbitration lost for mailbox 2<br>This bit is set when transmission failure is caused by an<br>arbitration lost in mailbox 2.                                                                                                                                                                                                                                                                                                                                                              |
| Bit 17              | TOK2             | rc_w1 | <ul> <li>Transmission OK of mailbox 2</li> <li>Hardware updates this bit after each transmission attempt in mailbox 2:</li> <li>0: The previous transmission fails.</li> <li>1: The previous transmission succeeds.</li> <li>This bit is set by hardware when the transmission request of mailbox 2 is completed successfully.</li> </ul>                                                                                                                                                  |
| Bit 16              | RQC2             | rc_w1 | Request completed mailbox 2<br>Set by hardware when the last request (transmit or abort) to<br>mailbox 2 is completed. Cleared by software writing '1' or by<br>hardware on transmission request (TRQ set in the CAN_TMI2<br>register).<br>Clearing this bit also clears other status bits (TOK2, ALS2,<br>and TER2) of mailbox 2.                                                                                                                                                         |



|            |      |        | Abort request for mailbox 1                                     |
|------------|------|--------|-----------------------------------------------------------------|
|            |      |        | Set by software to abort the transmission request of mailbox    |
| Bit 15     | ARQ1 | rs     | 1. Cleared by hardware when the mailbox 1 becomes empty.        |
|            |      |        | Setting this bit has no effect when the mailbox 1 is not        |
|            |      |        | pending for transmission.                                       |
| Bit 14:12  | -    | -      | Reserved. Forced to be '0' by hardware.                         |
|            |      |        | Transmission error of mailbox 1                                 |
| Bit 11     | TER1 | rc_w1  | This bit is set when transmission failure is caused by an error |
|            |      |        | in mailbox 1.                                                   |
|            |      |        | Arbitration lost for mailbox 1                                  |
| Bit 10     | ALS1 | rc_w1  | This bit is set when transmission failure is caused by an       |
|            |      |        | arbitration lost in mailbox 1.                                  |
|            |      |        | Transmission OK of mailbox 1                                    |
|            |      |        | Hardware updates this bit after each transmission attempt in    |
|            |      |        | mailbox 1:                                                      |
| Bit 9      | ΤΟΚ1 | rc_w1  | 0: The previous transmission fails.                             |
|            |      |        | 1: The previous transmission succeeds.                          |
|            |      |        | This bit is set by hardware when the transmission request of    |
|            |      |        | mailbox 1 is completed successfully.                            |
|            |      |        | Request completed mailbox 1                                     |
|            |      |        | Set by hardware when the last request (transmit or abort) to    |
|            |      |        | mailbox 1 is completed. Cleared by software writing `1' or by   |
| Bit 8      | RQC1 | rc_w1  | hardware on transmission request (TRQ set in the CAN_TMI1 $$    |
|            |      |        | register).                                                      |
|            |      |        | Clearing this bit also clears other status bits (TOK1, ALS1,    |
|            |      |        | and TER1) of mailbox 1.                                         |
|            |      |        | Abort request for mailbox 0                                     |
| Bit 7 ARQ0 | ARO0 | RQ0 rs | Set by software to abort the transmission request of mailbox    |
|            |      |        | 0. Cleared by hardware when the mailbox 0 becomes empty.        |
|            |      |        | Setting this bit has no effect when the mailbox 0 is not        |



|         |      |       | pending for transmission.                                                                                                                                                                                                                                                                                                                 |
|---------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 6:4 | -    | -     | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                                                                   |
| Bit 3   | TERO | rc_w1 | Transmission error of mailbox 0<br>This bit is set when transmission failure is caused by an error<br>in mailbox 0.                                                                                                                                                                                                                       |
| Bit 2   | ALS0 | rc_w1 | Arbitration lost for mailbox 0<br>This bit is set when transmission failure is caused by an<br>arbitration lost in mailbox 0.                                                                                                                                                                                                             |
| Bit 1   | токо | rc_w1 | <ul> <li>Transmission OK of mailbox 0</li> <li>Hardware updates this bit after each transmission attempt in mailbox 0:</li> <li>0: The previous transmission fails.</li> <li>1: The previous transmission succeeds.</li> <li>This bit is set by hardware when the transmission request of mailbox 0 is completed successfully.</li> </ul> |
| Bit 0   | RQC0 | rc_w1 | Request completed mailbox 0<br>Set by hardware when the last request (transmit or abort) to<br>mailbox 0 is completed. Cleared by software writing '1' or by<br>hardware on transmission request (TRQ set in the CAN_TMI0<br>register).<br>Clearing this bit also clears other status bits (TOK0, ALS0,<br>and TER0) of mailbox 0.        |

### 17.4.2.4 CAN Receive FIFO 0 Register (CAN\_RF0)

Address offset: 0x0C

Reset value: 0x00

| Bit           | Name  | Туре   | Description                                                                                          |
|---------------|-------|--------|------------------------------------------------------------------------------------------------------|
| Bit 31:6      | -     | -      | Reserved. Forced to be '0' by hardware.                                                              |
| Bit 5         | RRFM0 | rs     | Release receive FIFO 0 output mailbox<br>Set by software to release the FIFO output mailbox. Setting |
| Hango Hangzho |       | Hangzh | ou Vango Technologies, Inc. 665 / 782                                                                |

|         |           | i -   |                                                                |
|---------|-----------|-------|----------------------------------------------------------------|
|         |           |       | this bit when the receive FIFO is empty has no effect; it will |
|         |           |       | be meaningful only when there is message pending in the        |
|         |           |       | FIFO. If there are two or more messages pending in the         |
|         |           |       | FIFO, the software has to release the output mailbox to        |
|         |           |       | access the next message because of the FIFO features.          |
|         |           |       | Cleared by hardware when the output mailbox is released.       |
|         |           |       | FIFO 0 overrun                                                 |
|         | 5-01/0    |       | This bit is set by hardware when a new message is received     |
| Bit 4   | RFOV0     | rc_w1 | and passes the filter while the FIFO 0 is full.                |
|         |           |       | This bit is cleared by software.                               |
|         |           |       | FIFO 0 full                                                    |
| Bit 3   | RFFU0     | rc_w1 | Set by hardware when three messages are stored in the FIFO     |
|         |           |       | 0. This bit is cleared by software.                            |
| Bit 2   | -         | -     | Reserved. Forced to be '0' by hardware.                        |
|         |           |       | FIFO 0 message pending                                         |
|         |           | r     | These bits indicate the number of messages pending in the      |
|         |           |       | receive FIFO 0.                                                |
| Bit 1:0 | RFP0[1:0] |       | Each time when a new message is stored into the FIFO 0,        |
|         |           |       | RFP0 is added '1' by hardware. Each time when software         |
|         |           |       | writes `1' to the RRFM0 bit to release the output mailbox,     |
|         |           |       | RFP0 is deducted `1' until it becomes 0.                       |
| 1       |           |       |                                                                |

### 17.4.2.5 CAN Receive FIFO 1 Register (CAN\_RF1)

Address offset: 0x10

Reset value: 0x00

| Bit      | Name  | Туре | Description                                                    |  |
|----------|-------|------|----------------------------------------------------------------|--|
| Bit 31:6 | -     | -    | Reserved. Forced to be '0' by hardware.                        |  |
|          |       |      | Release FIFO 1 output mailbox                                  |  |
| Bit 5    | RRFM1 | rs   | Set by software to release the FIFO output mailbox. Setting    |  |
|          |       |      | this bit when the receive FIFO is empty has no effect; it will |  |



|           |       | be meaningful only when there is message pending in the    |
|-----------|-------|------------------------------------------------------------|
|           |       | FIFO. If there are two or more messages pending in the     |
|           |       | FIFO, the software has to release the output mailbox to    |
|           |       | access the next message because of the FIFO features.      |
|           |       | Cleared by hardware when the output mailbox is released.   |
|           |       | FIFO 1 overrun                                             |
| 55014     |       | This bit is set by hardware when a new message is received |
| RFOV1     | rc_w1 | and passes the filter while the FIFO 1 is full.            |
|           |       | This bit is cleared by software.                           |
|           |       | FIFO 1 full                                                |
| RFFU1     | rc_w1 | Set by hardware when three messages are stored in the FIFO |
|           |       | 1. This bit is cleared by software.                        |
| -         | -     | Reserved. Forced to be '0' by hardware.                    |
|           |       | FIFO 1 message pending                                     |
|           | r     | These bits indicate the number of messages pending in the  |
|           |       | receive FIFO 1.                                            |
| RFP1[1:0] |       | Each time when a new message is stored into the FIFO 1,    |
|           |       | RFP1 is added `1' by hardware Each time when software      |
|           |       | writes '1' to the RRFM1 bit to release the output mailbox, |
|           |       | RFP1 is deducted `1' until it becomes 0.                   |
|           | -     | RFFU1 rc_w1                                                |

#### 17.4.2.6 CAN Interrupts Enable Register (CAN\_INTEN)

Address offset: 0x14

Reset value: 0x0000 0000

|           |                                                        | 1: An interrupt is generated when the SAKIT bit is set.<br>Wakeup interrupt enable |                                                                                   |  |  |
|-----------|--------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|--|
| Bit 17    | SAKIErw0: No interrupt is generated when the SAKIT bit |                                                                                    | Sleep interrupt enable<br>0: No interrupt is generated when the SAKIT bit is set. |  |  |
| Bit 31:18 | -                                                      | -                                                                                  | Reserved. Forced to be '0' by hardware.                                           |  |  |
| Bit       | Name                                                   | Туре                                                                               | Description                                                                       |  |  |

|           | T       | 1  |                                                                                                                                                                                                                                                |
|-----------|---------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |         |    | 0: No interrupt is generated when the WKIT bit is set.                                                                                                                                                                                         |
|           |         |    | 1: An interrupt is generated when the WKIT bit is set.                                                                                                                                                                                         |
| Bit 15    | ERIE    | rw | <ul> <li>Error interrupt enable</li> <li>0: No interrupt is generated when error is pending in the</li> <li>CAN_ESTS register.</li> <li>1: An interrupt is generated when error is pending in the</li> <li>CAN_ESTS register.</li> </ul>       |
| Bit 14:12 | -       | -  | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                        |
| Bit 11    | ERCIE   | rw | <ul><li>Last error code interrupt enable</li><li>0: The ERIT bit is not set when ERC[2:0] is set by hardware</li><li>on error detection.</li><li>1: The ERIT bit is set when ERC[2:0] is set by hardware on</li><li>error detection.</li></ul> |
| Bit 10    | BUIE    | rw | Bus-off interrupt enable<br>0: The ERIT bit is not set when the BFF bit is set.<br>1: The ERIT bit is set when the BFF bit is set.                                                                                                             |
| Bit 9     | ERPIE   | rw | Error passive interrupt enable<br>0: The ERIT bit is not set when the ERPF bit is set.<br>1: The ERIT bit is set when the ERPF bit is set.                                                                                                     |
| Bit 8     | ERWIE   | rw | Error warning interrupt enable<br>0: The ERIT bit is not set when the ERWF bit is set.<br>1: The ERIT bit is set when the ERWF bit is set.                                                                                                     |
| Bit 7     | -       | -  | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                        |
| Bit 6     | RFOVIE1 | rw | <ul><li>FIFO 1 overrun interrupt enable</li><li>0: No interrupt is generated when the RFOV bit of FIFO 1 is set.</li><li>1: An interrupt is generated when the RFOV bit of FIFO 1 is set.</li></ul>                                            |
| Bit 5     | RFFUIE1 | rw | FIFO 1 full interrupt enable<br>0: No interrupt is generated when the RFFU bit of FIFO 1 is                                                                                                                                                    |



|       |         |    | set.<br>1: An interrupt is generated when the RFFU bit of FIFO 1 is<br>set.                                                                                                                                                                         |
|-------|---------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 4 | RFPIE1  | rw | <ul><li>FIFO message 1 pending interrupt enable</li><li>0: No interrupt is generated when the RFP[1:0] bit of FIFO 1</li><li>are not 00b.</li><li>1: An interrupt is generated when the RFP[1:0] bit of FIFO 1</li><li>are not 00b.</li></ul>       |
| Bit 3 | RFOVIE0 | rw | <ul><li>FIFO 0 overrun interrupt enable</li><li>0: No interrupt is generated when the RFOV bit of FIFO 0 is</li><li>set.</li><li>1: An interrupt is generated when the RFOV bit of FIFO 0 is</li><li>set.</li></ul>                                 |
| Bit 2 | RFFUIE0 | rw | <ul><li>FIFO 0 full interrupt enable</li><li>0: No interrupt is generated when the RFFU bit of FIFO 0 is</li><li>set.</li><li>1: An interrupt is generated when the RFFU bit of FIFO 0 is</li><li>set.</li></ul>                                    |
| Bit 1 | RFPIEO  | rw | <ul> <li>FIFO 0 message pending interrupt enable</li> <li>0: No interrupt is generated when the RFP[1:0] bit of FIFO 0</li> <li>are not 00b.</li> <li>1: An interrupt is generated when the RFP[1:0] bit of FIFO 0</li> <li>are not 00b.</li> </ul> |
| Bit 0 | TSMEIE  | rw | Transmit mailbox empty interrupt enable<br>0: No interrupt is generated when the RQCx bit is set.<br>1: An interrupt is generated when the RQCx bit is set.                                                                                         |

### 17.4.2.7 CAN Error Status Register (CAN\_ESTS)

Address offset: 0x18

Reset value: 0x0000 0000



| Bit       | Name     | Туре | Description                                                    |
|-----------|----------|------|----------------------------------------------------------------|
|           |          |      | Receive error counter                                          |
|           |          |      | This counter is implemented according to the Rx part of fault  |
|           |          |      | mechanism defined in CAN protocol. In case of a reception      |
|           |          |      | error, this counter is incremented by 1 or by 8 depending on   |
| Bit 31:24 | REC[7:0] | r    | the error condition specified in the CAN standard. After every |
|           |          |      | successful reception, the counter is decremented by 1, or is   |
|           |          |      | configured to 120 if its value is higher than 127. When the    |
|           |          |      | counter value exceeds 127, CAN enters error passive state.     |
|           |          |      | Least significant 8 bits of the 9-bit transmit error counter   |
| Bit 23:16 | TEC[7:0] | r    | Similar to the previous one, this counter is implemented       |
|           |          |      | according to the Tx part of fault mechanism defined in CAN     |
|           |          |      | protocol.                                                      |
| Bit 15:7  | -        | -    | Reserved. Forced to be '0' by hardware.                        |
|           | ERC[2:0] |      | Last error code                                                |
|           |          |      | Set by hardware according to the error condition on            |
|           |          |      | detection of CAN bus error. Cleared by hardware after          |
|           |          |      | message is correctly transmitted or received.                  |
|           |          | rw   | Hardware does not use error code 7; the value of this bit      |
|           |          |      | field can be configured by software, so the updates of the     |
|           |          |      | code can be monitored.                                         |
| Bit 6:4   |          |      | 000: No error                                                  |
|           |          |      | 001: Stuff error                                               |
|           |          |      | 010: Form error                                                |
|           |          |      | 011: Acknowledgment (ACK) error                                |
|           |          |      | 100: Bit recessive error                                       |
|           |          |      | 101: Bit dominant error                                        |
|           |          |      | 110: CRC error                                                 |
|           |          |      | 111: Set by software                                           |
| Bit 3     | -        | -    | Reserved. Forced to be '0' by hardware.                        |
| Bit 2     | BFF      | r    | Bus-off flag                                                   |



Hangzhou Vango Technologies, Inc.

|       |      |   | This bit is set by hardware when entering the bus-off state.<br>When the transmit error counter, TEC, overflows (greater<br>than 255), CAN enters bus-off state.                             |
|-------|------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 1 | ERPF | r | Error passive flag<br>This bit is set by hardware when the number of errors<br>reaches error passive threshold. (The value in the receive<br>error counter or transmit error counter > 127). |
| Bit 0 | ERWF | r | Error warning flag<br>This bit is set by hardware when number of errors reaches<br>the warning limit. (The value in the receive error counter or<br>transmit error counter $\geq$ 96).       |

## 17.4.2.8 CAN Bit Timing Register (CAN\_BTMG)

Address offset: 0x1C

Reset value: 0x0123 0000

| Bit       | Name     | Туре | Description                                             |
|-----------|----------|------|---------------------------------------------------------|
|           |          |      | Silent mode (debug)                                     |
| Bit 31    | SIL      | rw   | 0: Normal mode                                          |
|           |          |      | 1: Silent mode                                          |
|           |          |      | Loopback mode (debug)                                   |
| Bit 30    | LBK      | rw   | 0: Loopback mode is disabled.                           |
|           |          |      | 1: Loopback mode is enabled.                            |
| Bit 29:26 | -        | -    | Reserved. Forced to be '0' by hardware.                 |
|           |          |      | Resynchronization jump width                            |
|           |          |      | To perform the resynchronization, these bits define the |
| Bit 25:24 | SJW[1:0] | rw   | maximum number of time quanta that CAN hardware is      |
|           |          |      | allowed to lengthen or shorten in each bit.             |
|           |          |      | $tRJW = tCAN \times (SJW[1:0] + 1)$                     |
| Bit 23    | -        | -    | Reserved. Forced to be '0' by hardware.                 |



| Bit 22:20 | BS2[2:0]  | rw | Time segment 2<br>These bits define the number of time quanta in time segment<br>2.<br>tBS2 = tCAN x (BS2[2:0] + 1) |  |
|-----------|-----------|----|---------------------------------------------------------------------------------------------------------------------|--|
| Bit 19:16 | BS1[3:0]  | rw | Time segment 1<br>These bits define the number of time quanta in time segment<br>1.<br>tBS1 = tCAN × (BS1[3:0] + 1) |  |
| Bit 15:12 | -         | -  | Reserved. Forced to be '0' by hardware.                                                                             |  |
| Bit 11:0  | BRP[11:0] | rw | Baud rate prescaler<br>These bits define the length of a time quanta (tq).<br>tq = (BRP[11:0]+1) x tPCLK            |  |

#### **17.4.3 CAN Mailbox Register**

This section describes the registers of the transmit and receive mailboxes. Please refer to <u>Section 17.3.9</u> for more information about register mapping.

Transmit and receive mailboxes are almost the same except:

- The FID field in the CAN\_RDTxR register
- A receive mailbox is read-only.
- A transmit mailbox can be written only when it is empty (the corresponding TSME bit in the CAN\_TSTS register is set).

There are three Tx mailboxes and two Rx mailboxes. Each Rx mailbox is a 3-level depth FIFO, and can only access the oldest received message in the FIFO.

Each mailbox consists of four registers.

Figure 17-16 Tx and Rx Mailboxes





# 17.4.3.1 Tx Mailbox Identifier Register (CAN\_TMIx) (x = 0...2)

Address offset: 0x180, 0x190, 0x1A0

Reset value: 0xXXXX XXXX, X = Undefined (Except for Bit 0, TRQ = 0 at reset)

Note: 1. This register is write-protected when its mailbox is pending for transmission.

| 2. This register also | implements the | Tx request control | function (Bit 0) - | - Reset value is 0. |
|-----------------------|----------------|--------------------|--------------------|---------------------|
|-----------------------|----------------|--------------------|--------------------|---------------------|

| Bit       | Name                     | Туре | Description                                                                                                                                                                            |
|-----------|--------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:21 | SID[10:0]/<br>EID[28:18] | rw   | Standard identifier or extended identifier<br>Based on the IDT bit value, these bits are standard identifier or the<br>MSBs of extended identifier.                                    |
| Bit 20:3  | EID[17:0]                | rw   | Extended identifier<br>The LSBs of the extended identifier.                                                                                                                            |
| Bit 2     | IDT                      | rw   | Identifier extension<br>This bit defines the type of identifier of the mailbox messages.<br>0: Standard identifier<br>1: Extended identifier                                           |
| Bit 1     | RTR                      | rw   | Remote transmission request<br>0: Data frame<br>1: Remote frame                                                                                                                        |
| Bit 0     | TRQ                      | rw   | Transmit mailbox request<br>Set by software to request the transmission of mailbox data.<br>Cleared by hardware when data transmission is completed, and<br>the mailbox becomes empty. |



## 17.4.3.2 Mailbox Data Length and Time Stamp Register

### (CAN\_TDTx) (x = 0...2)

All bits of this register are write-protected when the mailbox is not in empty state.

Address offset: 0x184, 0x194, 0x1A4

Reset value: Undefined

| Bit       | Name      | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|-----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | TS[15:0]: | rw   | Message time stamp<br>This field contains the 16-bit timer value captured at the SOF<br>transmission.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 15:9  | -         | -    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 8     | TMEN      | w    | Transmit global time<br>This bit is active only when CAN is in time-triggered<br>communication mode, i.e. the TTC bit of the CAN_MCTRL register<br>is set.<br>0: Time stamp TS[15:0] is not sent.<br>1: Time stamp TS[15:0] is sent.<br>Time stamp, TS[15:0], is the last two data bytes sent in the 8-byte-<br>long message: TS[7:0] is the last two data bytes sent in the 8-byte-<br>long message: TS[7:0] is the data byte 7, and TS[15:8] is data byte<br>6; They replace the data written into CAN_TDHxR[31:16] (D6[7:0]<br>and D7[7:0]). DLC must be programmed as 8 in order to send these<br>two bytes of the time stamp. |
| Bit 7:4   | -         | -    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 3:0   | DLC[3:0]  | rw   | Data length code<br>This field defines the length of data bytes or requested by a<br>remote frame.<br>A message can contain from 0 to 8 data bytes, depending on the<br>value in the DLC field.                                                                                                                                                                                                                                                                                                                                                                                                                                    |



#### 17.4.3.3 Tx Mailbox Data Low Register (CAN\_TDLx) (x =

### 0...2)

All bits of this register are write-protected when the mailbox is not in empty state.

Address offset: 0x188, 0x198, 0x1A8

Reset value: Undefined

| Bit       | Name    | Туре | Description                               |
|-----------|---------|------|-------------------------------------------|
| Bit 31:24 | D3[7:0] | rw   | Data byte 3<br>Data byte 3 of the message |
| Bit 23:16 | D2[7:0] | rw   | Data byte 2<br>Data byte 2 of the message |
| Bit 15:8  | D1[7:0] | rw   | Data byte 1<br>Data byte 1 of the message |
| Bit 7:0   | D0[7:0] | rw   | Data byte 0<br>Data byte 0 of the message |

# 17.4.3.4 Tx Mailbox Data High Register (CAN\_TDHx) (x = 0...2)

All bits of this register are write-protected when the mailbox is not in empty state.

Address offset: 0x18C, 0x19C, 0x1AC

Reset value: Undefined

| Bit       | Name    | Туре | Description                                                    |
|-----------|---------|------|----------------------------------------------------------------|
|           |         |      | Data byte 7                                                    |
|           |         |      | Data byte 7 of the message                                     |
| Bit 31:24 | D7[7:0] | rw   | Note: If the TTC bit is set in the CAN_MCTRL register, and its |
|           |         |      | TMEN bit of the mailbox is also set, then D7 and D6 will be    |
|           |         |      | replaced by TS, time stamp.                                    |
| Bit 23:16 | D6[7:0] | rw   | Data byte 6                                                    |



|          |         |    | Data byte 6 of the message                |
|----------|---------|----|-------------------------------------------|
| Bit 15:8 | D5[7:0] | rw | Data byte 5<br>Data byte 5 of the message |
| Bit 7:0  | D4[7:0] | rw | Data byte 4<br>Data byte 4 of the message |

## 17.4.3.5 Rx FIFO Mailbox Identifier Register (CAN\_RFIx) (x

= 0...1)

Address offset: 0x1B0, 0x1C0

Reset value: Undefined

| Note: All Rx mail | box registers are | read-only. |
|-------------------|-------------------|------------|
|-------------------|-------------------|------------|

| Bit       | Name                     | Туре | Description                                                                                                                                         |
|-----------|--------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:21 | SID[10:0]/<br>EID[28:18] | r    | Standard identifier or extended identifier<br>Based on the IDT bit value, these bits are standard identifier or the<br>MSBs of extended identifier. |
| Bit 20:3  | EID[17:0]                | r    | Extended identifier<br>The LSBs of the extended identifier.                                                                                         |
| Bit 2     | IDT                      | r    | Identifier extension<br>This bit defines the type of identifier of the mailbox messages.<br>0: Standard identifier<br>1: Extended identifier        |
| Bit 1     | RTR                      | r    | Remote transmission request<br>0: Data frame<br>1: Remote frame                                                                                     |
| Bit 0     | -                        | -    | Reserved                                                                                                                                            |

#### 17.4.3.6 Rx FIFO Mailbox Data Length and Time Stamp

#### Register (CAN\_RDTx) (x = 0...1)

Address offset: 0x1B4, 0x1C4



#### Reset value: Undefined

| Bit       | Name     | Туре | Description                                                                                                                                                                                     |
|-----------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | TS[15:0] | r    | Message time stamp<br>This field contains the 16-bit timer value captured at the SOF<br>reception.                                                                                              |
| Bit 15:8  | FID[7:0] | r    | Filter match index<br>This register contains the filter index of message transfer stored in<br>the mailbox. For more details on identifier filtering, please refer to<br><u>Section 17.3.8.</u> |
| Bit 7:4   | -        | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                         |
| Bit 3:0   | DLC[3:0] | r    | Data length code<br>This field defines the number of data bytes a data frame contains<br>(0 ~ 8). For a remote frame request, DLC is always 0.                                                  |

# 17.4.3.7 Rx FIFO Mailbox Data High Register (CAN\_RDLx) (x = 0...1)

Address offset: 0x1B8, 0x1C8

Reset value: Undefined

Note: All Rx mailbox registers are read-only.

| Bit       | Name    | Туре | Description                               |
|-----------|---------|------|-------------------------------------------|
| Bit 31:24 | D3[7:0] | r    | Data byte 3<br>Data byte 3 of the message |
| Bit 23:16 | D2[7:0] | r    | Data byte 2<br>Data byte 2 of the message |
| Bit 15:8  | D1[7:0] | r    | Data byte 1<br>Data byte 1 of the message |
| Bit 7:0   | D0[7:0] | r    | Data byte 0<br>Data byte 0 of the message |



|  | A message can contain from 0 to 8 data bytes and starts with byte |
|--|-------------------------------------------------------------------|
|  | 0.                                                                |

# 17.4.3.8 Rx FIFO Mailbox Data High Register (CAN\_RDHx) (x = 0...1)

Address offset: 0x1BC, 0x1CC

Reset value: Undefined

Note: All Rx mailbox registers are read-only.

| Bit       | Name    | Туре | Description                               |
|-----------|---------|------|-------------------------------------------|
| Bit 31:24 | D7[7:0] | r    | Data byte 7<br>Data byte 7 of the message |
| Bit 23:16 | D6[7:0] | r    | Data byte 6<br>Data byte 6 of the message |
| Bit 15:8  | D5[7:0] | r    | Data byte 5<br>Data byte 5 of the message |
| Bit 7:0   | D4[7:0] | r    | Data byte 4<br>Data byte 4 of the message |

#### **17.4.4 CAN Filter Register**

#### 17.4.4.1 CAN Filter Main Control Register (CAN\_FM)

Address offset: 0x200

Reset value: 0x2A1C 0E01

| Bit      | Name | Туре | Description                                                                      |
|----------|------|------|----------------------------------------------------------------------------------|
| Bit 31:1 | -    | -    | Reserved. Forced to be reset value.                                              |
| Bit 0    | FINT | rw   | Filter Initialization mode<br>Selecting Initialization mode for all filter banks |

*Note: The non-reserved bits in this register are fully controlled by software.* 



|  | 0: Filter bank works in Normal mode.         |
|--|----------------------------------------------|
|  | 1: Filter bank works in Initialization mode. |

#### 17.4.4.2 CAN Filter Mode Register (CAN\_FM1)

Address offset: 0x204

Reset value: 0x0000 0000

*Note: This register can only be written when CAN\_FM is set* (*FINT = 1*), *which puts* filters in Initialization mode.

| Bit       | Name | Туре | Description                                                                                                                                                                                                                                 |
|-----------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:14 | -    | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                     |
| Bit 13:0  | FMSx | rw   | <ul> <li>Filter mode</li> <li>The operation mode of filter bank x.</li> <li>0: Two 32-bit registers of filter bank x are in identifier mask mode.</li> <li>1: Two 32-bit registers of filter bank x are in identifier list mode.</li> </ul> |

#### 17.4.4.3 CAN Filter Scale Register (CAN\_FS1)

Address offset: 0x20C

Reset value: 0x0000 0000

*Note: This register can only be written when CAN\_FM is set (FINT = 1), which puts* filters in Initialization mode.

| Bit       | Name | Туре | Description                                                                                                                                                  |
|-----------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:14 | -    | -    | Reserved. Forced to be '0' by hardware.                                                                                                                      |
| Bit 13:0  |      |      | Filter bit scale configuration                                                                                                                               |
|           | FROM | -    | <ul> <li>Scale configuration of filter banks x (13 ~ 0)</li> <li>0: Dual 16-bit scale configuration</li> <li>1: Single 32-bit scale configuration</li> </ul> |
|           | FBSx | rw   |                                                                                                                                                              |
|           |      |      |                                                                                                                                                              |

#### 17.4.4.4 CAN Filter FIFO Assignment Register (CAN\_FFA1)

Address offset: 0x214



#### Reset value: 0x0000 0000

*Note: This register can only be written when CAN\_FM is set (FINT = 1), which puts filters* in Initialization mode.

| Bit       | Name | Туре | Description                                                                                                                                                                                                                               |
|-----------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:14 | -    | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                   |
| Bit 13:0  | FAFx | rw   | <ul> <li>Filter assignment for FIFO configuration</li> <li>The message passing through certain filter will be stored in the assigned FIFO.</li> <li>0: Filter is assigned to FIFO 0.</li> <li>1: Filter is assigned to FIFO 1.</li> </ul> |

#### 17.4.4.5 CAN Filter Activation Register (CAN\_FA1)

Address offset: 0x21C

Reset value: 0x0000 0000

| Bit       | Name | Туре | Description                                                                                                                                                                                                                                                                                                                      |
|-----------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:14 | -    | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                                                          |
| Bit 13:0  | FENx | rw   | <ul> <li>Filter active</li> <li>Software sets a certain bit to activate the corresponding filter. To modify the corresponding filter registers x (CAN_FBiRx), the FENx bit must be cleared, or the FINT bit of the CAN_FM register must be set.</li> <li>0: Filter is not activated.</li> <li>1: Filter is activated.</li> </ul> |

#### 17.4.4.6 CAN Filter Bank i Register x (CAN\_FBiRx) (where i

#### = 0...13; x = 1...2)

Address offset: 0x240h...0x31C

Reset value: Undefined

Note: The filter register can only be modified when the corresponding FENx bit of the CAN\_FA1 register



is cleared, or when the FINT bit of the CAN\_FM register is set.

In all configurations:

| Bit      | Name     | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | FD[31:0] | rw   | Filter bits<br>Identifier mode<br>Each bit of the register specifies the level of the corresponding bit<br>of the expected identifier.<br>0: Dominant bit is expected.<br>1: Recessive bit is expected.<br>Mask mode<br>Each bit of the register specifies whether the bit of the associated<br>identifier register must match with the corresponding bit of the<br>expected identifier.<br>0: Don't care. The bit is not used for the comparison.<br>1: Must match. The bit of the incoming identifier must have the<br>same level specified in the corresponding identifier register of the<br>filter. |

*Note:* According to the different configurations of the scale and mode, the functions of the two registers may differ. Please refer to <u>Section 17.3.8</u> for more details about filter mapping, function overview, and mask register association.



## **18 External Memory Controller (XMC)**

## 18.1 Introduction

The XMC block can interface with synchronous and asynchronous memories. Its main functions are:

- Translating the AHB transactions into the appropriate external device protocol
- Meeting the timing requirements to access the external devices

All external memories share the addresses, data, and control signals with the controller. Each external device is accessed by a unique chip-select signal. XMC performs only one access to an external device at a time.

XMC has the following main functions:

- Devices with static memory-mapped interfaces, including:
  - Static Random Access Memory (SRAM)
  - NOR Flash memory
  - PSRAM (2 memory banks)
- 1 NAND Flash memory bank which supports ECC hardware and check-up to 8 Kbytes ofdata
- Supports burst mode access to synchronous devices, e.g. NOR Flash and PSRAM
- 8-bit or 16-bit wide data bus
- Independent chip-select control for each memory bank
- Independent configuration for each memory bank
- Programmable timings to support a wide range of devices:
  - Programmable wait states (Up to 15 cycles)
  - Programmable bus turnaround cycles (Up to 15 cycles)
  - Programmable output enable and write enable delays (Up to 15 cycles)
  - Independent read and write timings and protocol to support a wide variety of memories and timings
- Write enable and byte lane select outputs used by PSRAM and SRAM devices
- Translation of 32-bit wide AHB transactions into consecutive 16-bit or 8-bit accesses to external 16-bit

or 8-bit devices

A 2-word-long write FIFO, with each word 32-bit wide. It only buffers AHB write burst transactions,



which allows to free AHB for other operations when writing to slow memories. Before a new XMC operation, the FIFO should be cleared.

Usually before system reset or power-on, XMC registers that define the external device type and characteristics should be configured, and kept unchanged. Also, users can change the configurations anytime if needed.

## 18.2 Main Features

### 18.2.1 Block Diagram

XMC consists of four main blocks:

- AHB interface (including XMC configuration registers)
- NOR Flash and PSRAM controller
- NAND Flash controller
- External device interface

Figure 18-1 is the block diagram of XMC:

Figure 18-1 XMC Block Diagram





#### 18.2.2 AHB Interface

The AHB interface provides channels for internal CPU and other bus peripherals to access the external static memories.

AHB transactions are converted into the external device protocol. If the selected external memory is 16bit or 8-bit wide, 32-bit wide transactions on the AHB are split into consecutive 16-bit or 8-bit accesses.

AHB clock (HCLK) is the reference clock for XMC.

#### **18.2.3 Supported Memories and Transactions**

#### 18.2.3.1 General transaction rules

Data size of requested AHB transactions can be 8-bit, 16-bit, or 32-bit wide, whereas the accessed external device has a fixed data width. This may lead to inconsistent transfers.

Therefore, to ensure the consistency of data transfer, XMC follows the rules below:

• AHB transaction size and memory data size are equal: There is no issue in this case.



• AHB transaction size is greater than the memory size: In this case, XMC splits the AHB transaction into smaller consecutive memory accesses to meet the external data width.

• AHB transaction size is smaller than the memory size:

According to the type of external device, asynchronous transfers may be inconsistent.

During asynchronous accesses to memories with byte select features (SRAM, ROM, and PSRAM, etc.),
 XMC performs transactions to access the right data via its byte lanes, NBL[1:0].

— During asynchronous accesses to memories without byte select features (NOR and 16-bit NAND, etc.), a byte access is requested to a 16-bit wide Flash memory; apparently, memories cannot be accessed in byte mode (only 16-bit data transfer is allowed), so:

a. Write transactions are not allowed.

b. Read transactions are allowed. (Controllers read the complete 16-bit memory data and only use bytes needed.)

#### Supported memory

This XMC model only has A[23:16] and A[0] of address line, so NOR Flash and PSRAM controller only support alternate memory; however, non-alternate read/write function is still reserved for flexible usages according to signals shown in Figure 18-1.

#### Configuration registers

XMC can be configured by a register set. <u>Section 18.4</u> describes the NOR Flash, the PSRAM control register, and the NAND Flash registers in detail.

# **18.3 Function Overview**

# 18.3.1 Address Mapping

From XMC point of view, the external memory is divided into 2 fixed-size banks of 32 Mbytes; please refer to Figure 18-2:

- Bank 1 is used to address up to 2 NOR Flash or PSRAM memory devices. This bank is split into 2 NOR/PSRAM sub-banks with 2 dedicated chip selects.
- Banks 2 is used to address NAND Flash devices.

The type of memory on each bank is user-defined in the configuration register.

Hangzhou Vango Technologies, Inc.

#### Figure 18-2 XMC Memory Banks



### 18.3.1.1 NOR and PSRAM Address Mapping

HADDR[27:26] can be used to select one of the 2 memory banks:

Table 18-1 NOR/PSRAM Memory Bank Selection

| HADDR[27:26] (Note) | Selected Bank     |
|---------------------|-------------------|
| 00                  | Bank 1 NOR/PSRAM1 |
| 11                  | Bank 1 NOR/PSRAM4 |

Note: HADDR are internal AHB address lines that need to be converted to external memory.

The HADDR[23:0] bits contain the external memory address. Since HADDR is a byte address, and the memory is addressed in words, the address line connected to the memory varies according to the memory data width, as shown in Table 18-2:

Table 18-2 External Memory Address

| Data Width | Data Address Issued to the Memory | Maximum Memory Capacity |
|------------|-----------------------------------|-------------------------|
| (Note)     |                                   | (bit)                   |



| 8-bit  | HADDR[23:0] to XMC_A[23:0]                      | 16 Mbyte x 8 = 128 Mbits    |
|--------|-------------------------------------------------|-----------------------------|
| 16-bit | HADDR[23:1] to XMC_A[22:0], HADDR[0] not issued | 16 Mbyte/2 x 16 = 128 Mbits |

*Note:* 1. In case of a 16-bit external memory width, XMC will internally use HADDR[23:1] to generate the address for external memory XMC\_A[22:0]. Whatever the external memory width (16-bit or 8-bit) is, XMC\_A[0] should always be connected to external memory address A[0].

2. XMC\_A[15:1] is not output pin; in alternate mode, low address A[15:0] will be transmitted as XMC\_D[15:0]; otherwise, A[15:1] cannot be outputted.

#### Wrap support for NOR Flash and PSRAM

Every NOR Flash or PSRAM memory bank can be configured as wrap burst mode.

For memories, the following two situations should be taken into account depending on asynchronous or synchronous access:

• Asynchronous mode: Under this condition, as long as each access has an accurate address, wrap burst mode is fully supported.

• Synchronous mode: Under this condition, XMC only sends one address signal, and then data is transferred in burst mode by CLK order.

Some NOR memories support linear wrap burst mode accesses; data bytes with fixed number can be read from consecutive module N address (Typically, N is 8 or 16, which can be configured through the NOR Flash configuration register.) In this case, wrap burst mode of the memory can be configured as the same mode of AHB.

If wrap burst mode of the memory cannot be configured as the same mode of AHB, the corresponding bits in the XMC configuration register should be set to disable the wrap burst mode, and split the wrap burst accesses into two consecutive accesses.

### 18.3.1.2 NAND Address Mapping

This bank can be used for NAND accesses, and is separated into the following access space:

| Start Address | End Address | XMC Memory Bank     | Memory<br>Space | Timing Register      |
|---------------|-------------|---------------------|-----------------|----------------------|
| 0x78000000    | 0x78FFFFFF  | Bank 2 – NAND Flash | Attribute       | XMC_BK2TMGATT (0x6C) |

Table 18-3 Memory Mapping and Timing Registers



| 0x70000000 | 0x70FFFFFF |  | Common | XMC_BK2TMGMEM (0x68) |
|------------|------------|--|--------|----------------------|
|------------|------------|--|--------|----------------------|

For NAND Flash memory, the common and attribute memory spaces are subdivided into three sections (See Table 18-4) located in the lower 256 Kbytes:

- Data section (The first 64 Kbytes in the common/attribute memory space)
- Command section (The second 64 Kbytes in the common/attribute memory space)
- Address section (The next 128 Kbytes in the common/attribute memory space)

Table 18-4 NAND Bank Selection

| Section Name    | HADDR[17:16] | Address Range       |  |
|-----------------|--------------|---------------------|--|
| Address section | 1X           | 0x020000 ~ 0x03FFFF |  |
| Command section | 01           | 0x010000 ~ 0x01FFFF |  |
| Data section    | 00           | 0x000000 ~ 0x00FFFF |  |

The application software uses the 3 sections to access the NAND Flash memory:

• To send a command to the NAND Flash memory: The software only needs to write the command value to any address in the command section.

• To specify the NAND Flash address: The software only needs to write the address value to any address in the address section. Since a NAND address can be 4-byte or 5-byte long (depending on the actual memory size), several consecutive writes to the address section are needed to specify the full address.

• To read or write data: The software only needs to read or write the data value to any address in the data section.

Since the NAND Flash memory automatically increments addresses, there is no need to increment the address of the data section to access consecutive memory locations.

### **18.3.2 NOR Flash/PSRAM Controller**

XMC can generate appropriate signal timings to drive the following types of memories:

- Asynchronous SRAM and ROM
  - 8-bit



- 32-bit
- PSRAM (Cellular RAM)
  - Asynchronous mode
  - Burst mode
- NOR Flash
  - Asynchronous mode or Burst mode
  - Multiplexed mode or non-multiplexed mode

XMC outputs a unique chip-select signal, NE[4] and NE[1], to each bank. All the other signals (addresses, data, and control) are shared.

For synchronous accesses, XMC issues the clock (CLK) to the selected external device. The frequency of the clock is a submultiple of the HCLK clock. The size of each bank is fixed to 16 Mbytes.

Each bank is configured by dedicated registers (See Section 18.4).

The programmable memory parameters include access timings (See Table 18-5), whether to support wrap burst data access, and wait management (only for PSRAM and NOR Flash accessed in burst mode).

Table 18-5 Programmable NOR/PSRAM Access Parameters

| Parameter    | Function                             | Access Mode      | Unit         | Min. | Max. |
|--------------|--------------------------------------|------------------|--------------|------|------|
| Address      | Duration of the address setup phase  | Asynchronous     | AHB clock    | 1    | 16   |
| setup        |                                      |                  | cycle (HCLK) |      |      |
| Address hold | Duration of the address hold phase   | Asynchronous and | AHB clock    | 2    | 16   |
|              |                                      | muxed I/Os       | cycle (HCLK) |      |      |
| Data setup   | Duration of the data setup phase     | Asynchronous     | AHB clock    | 2    | 256  |
|              |                                      |                  | cycle (HCLK) |      |      |
| Bus turn     | Duration of the bus turnaround       | Asynchronous or  | AHB clock    | 1    | 16   |
|              | phase                                | synchronous read | cycle (HCLK) |      |      |
| Clock divide | Ratio between memory access clock    | Synchronous      | AHB clock    | 2    | 16   |
| ratio        | cycle (CLK) and AHB clock cycles     |                  | cycle (HCLK) |      |      |
| Data latency | Number of clock cycles needed to     | Synchronous      | Memory clock | 2    | 17   |
|              | generate the first data in the burst |                  | cycle (CLK)  |      |      |
|              | mode                                 |                  |              |      |      |



### 18.3.2.1 External Memory Interface Signal

Table 18-6, Table 18-7, and Table 18-8 list the signals that are typically used to interface the NOR Flash and PSRAM.

*Note: Signals with the prefix "N" are active low.* 

#### NOR Flash, non-multiplexed I/Os

Table 18-6 Non-multiplexed I/Os of NOR Flash Interface

| XMC Signal Name   | Direction | Function                                                    |  |
|-------------------|-----------|-------------------------------------------------------------|--|
| CLK               | 0         | Clock (for synchronous burst mode)                          |  |
| A[23:16] and A[0] | 0         | Address bus                                                 |  |
| D[15:0]           | I/O       | Bidirectional data bus                                      |  |
| NE[x]             | 0         | Chip select, $x = 1$ and 4                                  |  |
| NOE               | 0         | Output enable                                               |  |
| NWE               | 0         | Write enable                                                |  |
| NL (= NADV)       | 0         | Latch enable (This signal is called address valid, NADV, by |  |
|                   |           | some NOR Flash devices.)                                    |  |
| NWAIT             | Ι         | NOR Flash signal requesting XMC to wait                     |  |

NOR Flash memories are addressed by 16-bit words. However, A[15:1] is not outputted.

#### NOR Flash, multiplexed I/Os

Table 18-7 Multiplexed I/Os of NOR Flash Interface

| XMC Signal Name | Direction | Function                                                    |  |  |
|-----------------|-----------|-------------------------------------------------------------|--|--|
| CLK             | 0         | Clock (for synchronous burst mode)                          |  |  |
| A[23:16]        | 0         | Address bus                                                 |  |  |
| AD[15:0]        | I/O       | 16-bit multiplexed, bidirectional address/data bus          |  |  |
| NE[x]           | 0         | Chip select, $x = 1$ and 4                                  |  |  |
| NOE             | 0         | Output enable                                               |  |  |
| NWE             | 0         | Write enable                                                |  |  |
| NL (= NADV)     | 0         | Latch enable (This signal is called address valid, NADV, by |  |  |



|       |   | some NOR Flash devices.)                |  |  |
|-------|---|-----------------------------------------|--|--|
| NWAIT | Ι | NOR Flash signal requesting XMC to wait |  |  |

NOR Flash memories are addressed by 16-bit words. The maximum capacity is 16 Mbytes (8 address lines and 16 bidirectional address/data lines).

#### PSRAM

Table 18-8 Non-multiplexed I/Os of PSRAM Interface

| XMC Signal Name   | Direction | Function                                                     |  |
|-------------------|-----------|--------------------------------------------------------------|--|
| CLK               | 0         | Clock (for synchronous burst mode)                           |  |
| A[23:16] and A[0] | 0         | Address bus                                                  |  |
| D[15:0]           | I/O       | Bidirectional data bus                                       |  |
| NE[x]             | 0         | Chip select, $x = 1$ and 4 (called as NCE by PSRAM (Cellular |  |
|                   |           | RAM i.e. CRAM))                                              |  |
| NOE               | 0         | Output enable                                                |  |
| NWE               | 0         | Write enable                                                 |  |
| NL( = NADV)       | 0         | Address valid (memory signal name: NADV)                     |  |
| NWAIT             | Ι         | PSRAM signal requesting XMC to wait                          |  |
| NBL[1]            | 0         | Upper byte enable (memory signal name: NUB)                  |  |
| NBL[0]            | 0         | Lower byte enable (memory signal name: NLB)                  |  |

PSRAM memories are addressed by 16-bit words. However, A[15:1] is not outputted.

### **18.3.2.2** Supported Memories and Transactions

Table 18-9 lists the supported memories, access modes, and transactions; XMC does not support the transactions in gray.

|           |              |     | AHB  | Memory | Allowed/ |         |
|-----------|--------------|-----|------|--------|----------|---------|
| Memory    | Mode         | R/W | Data | Data   | Not      | Comment |
|           |              |     | Size | Size   | Allowed  |         |
| NOR Flash | Asynchronous | R   | 8    | 16     | Yes      |         |

Table 18-9 Supported NOR Flash/PSRAM Memory and Transaction of XMC



|                         |                      |     |         |    |     | recinical Handal               |
|-------------------------|----------------------|-----|---------|----|-----|--------------------------------|
| (Muxed I/Os             | Asynchronous         | W   | 8       | 16 | No  |                                |
| and Non-                | Asynchronous         | R   | 16      | 16 | Yes |                                |
| muxed I/Os)             | Asynchronous         | W   | 16      | 16 | Yes |                                |
|                         | Asynchronous         | R   | 32      | 16 | Yes | Split into two XMC<br>accesses |
|                         | Asynchronous         | W   | 32      | 16 | Yes | Split into two XMC accesses    |
|                         | Asynchronous pag     | e R | -       | 16 | No  | This mode is not supported.    |
|                         | Synchronous          | R   | 8       | 16 | No  |                                |
|                         | Synchronous          | R   | 16      | 16 | Yes |                                |
|                         | Synchronous          | R   | 32      | 16 | Yes |                                |
|                         | Asynchronous         | R   | 8       | 16 | Yes |                                |
|                         | Asynchronous         | W   | 8       | 16 | Yes | Use byte signal NBL[1:0]       |
|                         | Asynchronous         | R   | 16      | 16 | Yes |                                |
|                         | Asynchronous         | W   | 16      | 16 | Yes |                                |
|                         | Asynchronous         | R   | 32      | 16 | Yes | Split into two XMC<br>accesses |
| PSRAM<br>(Muxed I/Os    | Asynchronous         | W   | 32      | 16 | Yes | Split into two XMC<br>accesses |
| and Non-<br>muxed I/Os) | Asynchronous<br>page | R   | -       | 16 | No  | This mode is not<br>supported. |
|                         | Synchronous          | R   | 8       | 16 | No  |                                |
|                         | Synchronous          | R   | 16      | 16 | Yes |                                |
|                         | Synchronous          | R   | 32      | 16 | Yes |                                |
|                         | Synchronous          | W   | 8       | 16 | Yes | Use byte signal NBL[1:0]       |
|                         | Synchronous          | W   | 16/32   | 16 | Yes |                                |
| SRAM and ROM            | Asynchronous         | R   | 8/16/32 | 16 | Yes | Use byte signal NBL[1:0]       |



| Asynchronous | W | 8/16/32 | 16 | Yes | Use byte signal NBL[1:0] |
|--------------|---|---------|----|-----|--------------------------|
|--------------|---|---------|----|-----|--------------------------|

### 18.3.2.3 Timing Rules

#### Signals synchronization

• All controller output signals change on the rising edge of the internal clock (HCLK).

• In synchronous mode (PSRAM read or write), all output data changes on the falling edge of memory clock (CLK).

# 18.3.2.4 NOR Flash and PSRAM Controller Timing Diagram

#### Asynchronous static memories (NOR Flash, PSRAM, and SRAM)

• All signals are synchronized by the internal clock, HCLK, but this clock is not issued to the memory.

• XMC always samples the data before the NOE signals become invalid. This guarantees that the memory data-hold timing constraint is met (The interval between chip-select invalid and data invalid is usually 0 ns (the min.)).

• If the extended mode is enabled, it is possible to mix mode A, B, C, and D for read and write operations. (For example, read operation can be performed in mode A, and write operation is performed in mode B.)

#### Mode 1——SRAM/PSRAM (CRAM)

Figure 18-3 Mode 1 Read Access





Note: A[15:1] is not outputted.

#### Figure 18-4 Mode 1 Write Access



Note: A[15:1] is not outputted.

The last HCLK cycle of write transaction helps guarantee the address and data hold time after the NWE

rising edge. Due to the presence of this HCLK cycle, the DTOP value must be greater than 0 (DTOP > 0).

```
Table 18-10 XMC_BK1CTRLx Bit Field (Mode 1)
```

| Dit Number | Dit Nama  | Value Cet                                                     |
|------------|-----------|---------------------------------------------------------------|
| Bit Number | Bit Name  | Value Set                                                     |
| 31-16      |           | 0×0000                                                        |
| 15         | WAITASYNC | Set to 1 if the memory supports this feature. Otherwise, keep |
|            |           | at 0.                                                         |
| 14-10      |           | 0×0                                                           |
| 9          | WAITALV   | Meaningful only if the bit 15 is '1'.                         |
| 8          | BURSTEN   | 0×0                                                           |
| 7          |           | -                                                             |
| 6          | NOREN     | -                                                             |
| 5-4        | BUSTYPE   | Set as needed                                                 |
| 3-2        | DEV       | Set as needed, excluding 0x2 (NOR Flash)                      |
| 1          | MUXEN     | 0×0                                                           |
| 0          | EN        | 0×1                                                           |

Table 18-11 XMC\_BK1TMGx Bit Field (Mode 1)

| Bit Number | Bit Name | Value Set                                                    |
|------------|----------|--------------------------------------------------------------|
| 31-20      |          | 0×0000                                                       |
| 19-16      | INTVLOP  | Time between NEx high to NEx low (INTVLOP HCLK)              |
| 15-8       | DTOP     | Duration of the second access phase, DTOP + 1 HCLK cycle for |
|            |          | write accesses, DTOP + 3 HCLK cycles for read accesses       |
|            |          | This field cannot be 0, and the minimum value is 1.          |
| 7-4        |          | 0x0                                                          |
| 3-0        | ADROP    | Duration of the first access phase (ADROP + 1 HCLK cycle)    |

#### Mode A--SRAM/PSRAM (CRAM) OE toggling

Figure 18-5 Mode A Read Access





Note: A[15:1] is not outputted.

Figure 18-6 Mode A Write Access



Note: A[15:1] is not outputted.

The difference between mode A and mode 1 is the toggling of NOE and the independent read/write timings.

```
Table 18-12 XMC_BK1CTRLx Bit Field (Mode A)
```



| Bit Number | Bit Name  | Value Set                                                        |
|------------|-----------|------------------------------------------------------------------|
| 31-16      |           | 0×0000                                                           |
| 15         | WAITASYNC | Set to 1 if the memory supports this feature. Otherwise, keep at |
|            |           | 0.                                                               |
| 14         | TMGWREN   | 0x1                                                              |
| 13-10      |           | 0x0                                                              |
| 9          | WAITALV   | Meaningful only if the bit 15 is `1'.                            |
| 8          | BURSTEN   | 0x0                                                              |
| 7          |           | -                                                                |
| 6          | NOREN     | -                                                                |
| 5-4        | BUSTYPE   | Set as needed                                                    |
| 3-2        | DEV       | Set as needed, excluding 0x2 (NOR Flash)                         |
| 1          | MUXEN     | 0x0                                                              |
| 0          | EN        | 0x1                                                              |

#### Table 18-13 XMC\_BK1TMGx Bit Field (Mode A)

| Bit Number | Bit Name | Value Set                                                         |
|------------|----------|-------------------------------------------------------------------|
| 31-30      |          | 0x0                                                               |
| 29-28      | MODE     | 0x0                                                               |
| 27-20      |          | 0x000                                                             |
| 19-16      | INTVLOP  | Time between NEx high to NEx low (INTVLOP HCLK)                   |
| 15-8       | DTOP     | Duration of the second phase of read access (DTOP + 3 HCLK        |
|            |          | cycles) This field cannot be 0, and the minimum value is 1.       |
| 7-4        |          | 0x0                                                               |
| 3-0        | ADROP    | Duration of the first phase of read access (ADROP + 1 HCLK cycle) |

#### Table 18-14 XMC\_BK1TMGWRx Bit Field (Mode A)

| Bit Number | Bit Name | Value Set |
|------------|----------|-----------|
| 31-30      |          | 0x0       |
| 29-28      | MODE     | 0x0       |



| 27-20 |         | 0×000                                                              |
|-------|---------|--------------------------------------------------------------------|
| 19-16 | INTVLOP | Time between NEx high to NEx low (INTVLOP HCLK)                    |
| 15-8  | DTOP    | Duration of the second access phase, DTOP + 1 HCLK cycle for       |
|       |         | write accesses, DTOP + 3 HCLK cycles for read accesses             |
|       |         | This field cannot be 0, and the minimum value is 1.                |
| 7-4   |         | 0×0                                                                |
| 3-0   | ADROP   | Duration of the first phase of write access (ADROP + 1 HCLK cycle) |

#### Mode 2/B——NOR Flash





Note: A[15:1] is not outputted.

Figure 18-8 Mode 2 Write Access





Note: A[15:1] is not outputted.

Figure 18-9 Mode B Write Access





The difference between Mode 2/B and Mode A is the NADV toggling, and the independent read/write

timings in extended mode (Mode B).



| Table 18-15 XMC_BK1CTRLx Bit Field (Mode 2/B) |           |                                                                  |  |
|-----------------------------------------------|-----------|------------------------------------------------------------------|--|
| Bit Number                                    | Bit Name  | Value Set                                                        |  |
| 31-16                                         |           | 0×0000                                                           |  |
| 15                                            | WAITASYNC | Set to 1 if the memory supports this feature. Otherwise, keep at |  |
|                                               |           | 0.                                                               |  |
| 14                                            | TMGWREN   | Mode B: 0x1; Mode 2: 0x0                                         |  |
| 13-10                                         |           | 0x0                                                              |  |
| 9                                             | WAITALV   | Meaningful only if the bit 15 is '1'.                            |  |
| 8                                             | BURSTEN   | 0x0                                                              |  |
| 7                                             |           | -                                                                |  |
| 6                                             | NOREN     | 0x1                                                              |  |
| 5-4                                           | BUSTYPE   | Set as needed                                                    |  |
| 3-2                                           | DEV       | 0x2 (NOR Flash)                                                  |  |
| 1                                             | MUXEN     | 0×0                                                              |  |
| 0                                             | EN        | 0x1                                                              |  |

Table 18-16 XMC\_BK1TMGx Bit Field (Mode 2/B)

| Bit Number | Bit Name | Value Set                                                            |
|------------|----------|----------------------------------------------------------------------|
| 31-30      |          | 0×0                                                                  |
| 29-28      | MODE     | 0x1                                                                  |
| 27-20      |          | 0x000                                                                |
| 19-16      | INTVLOP  | Time between NEx high to NEx low (INTVLOP HCLK)                      |
| 15-8       | DTOP     | Duration of the second phase of read access (DTOP + 3 HCLK           |
|            |          | cycles) This field cannot be 0, and the minimum value is 1.          |
| 7-4        |          | 0×0                                                                  |
| 3-0        | ADROP    | Duration of the first phase of read access (ADROP + $1 \text{ HCLK}$ |
|            |          | cycle)                                                               |

Table 18-17 XMC\_BK1TMGWRx Bit Field (Mode 2/B)

| Bit Number | Bit Name | Value Set                      |           |
|------------|----------|--------------------------------|-----------|
| 31-30      |          | 0x0                            |           |
| ango       | Han      | gzhou Vango Technologies, Inc. | 700 / 782 |

| 29-28 | MODE    | 0×1                                                                                                                                                                           |
|-------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27-20 |         | 0×000                                                                                                                                                                         |
| 19-16 | INTVLOP | Time between NEx high to NEx low (INTVLOP HCLK)                                                                                                                               |
| 15-8  | DTOP    | Duration of the second access phase, DTOP + 1 HCLK cycle for<br>write accesses, DTOP + 3 HCLK cycles for read accesses<br>This field cannot be 0, and the minimum value is 1. |
| 7-4   |         | 0×0                                                                                                                                                                           |
| 3-0   | ADROP   | Duration of the first phase of write access (ADROP + 1 HCLK cycle)                                                                                                            |

Note: XMC\_BK1TMGWRx is valid only when extended mode (Mode B) is set; otherwise, this register has no effect. Mode C——NOR Flash-OE toggling

Figure 18-10 Mode C Read Access





Figure 18-11 Mode C Write Access





Note: A[15:1] is not outputted.

The difference between Mode C and Mode1 is the NOE and NADV toggling, and the independent read/write timings.

| Table 18-18 XMC_BK1CTRLx Bit Field ( | Mode C) |
|--------------------------------------|---------|
|--------------------------------------|---------|

| Bit Number | Bit Name                                                               | Value Set                             |  |
|------------|------------------------------------------------------------------------|---------------------------------------|--|
| 31-16      |                                                                        | 0×0000                                |  |
| 15         | WAITASYNC Set to 1 if the memory supports this feature. Otherwise, kee |                                       |  |
|            |                                                                        | 0.                                    |  |
| 14         | TMGWREN                                                                | 0x1                                   |  |
| 13-10      |                                                                        | 0x0                                   |  |
| 9          | WAITALV                                                                | Meaningful only if the bit 15 is '1'. |  |
| 8          | BURSTEN                                                                | 0x0                                   |  |
| 7          |                                                                        | -                                     |  |
| 6          | NOREN                                                                  | 0x1                                   |  |
| 5-4        | BUSTYPE                                                                | Set as needed                         |  |
| 3-2        | DEV                                                                    | 0x2 (NOR Flash)                       |  |



| 1 | MUXEN | 0x0 |
|---|-------|-----|
| 0 | EN    | 0x1 |

#### Table 18-19 XMC\_BK1TMGx Bit Field (Mode C)

| Bit Number | Bit Name | Value Set                                                                                                              |
|------------|----------|------------------------------------------------------------------------------------------------------------------------|
| 31-30      |          | 0×0                                                                                                                    |
| 29-28      | MODE     | 0x2                                                                                                                    |
| 27-20      |          | 0x000                                                                                                                  |
| 19-16      | INTVLOP  | Time between NEx high to NEx low (INTVLOP HCLK)                                                                        |
| 15-8       | DTOP     | Duration of the second phase of read access (DTOP + 3 HCLK cycles) This field cannot be 0, and the minimum value is 1. |
| 7-4        |          | 0×0                                                                                                                    |
| 3-0        | ADROP    | Duration of the first phase of read access (ADROP + 1 HCLK cycle)                                                      |

#### Table 18-20 XMC\_BK1TMGWRx Bit Field (Mode C)

| Bit Number | Bit Name | Value Set                                                             |  |
|------------|----------|-----------------------------------------------------------------------|--|
| 31-30      |          | 0×0                                                                   |  |
| 29-28      | MODE 0x2 |                                                                       |  |
| 27-20      |          | 0x000                                                                 |  |
| 19-16      | INTVLOP  | Time between NEx high to NEx low (INTVLOP HCLK)                       |  |
| 15-8       | DTOP     | Duration of the second access phase, DTOP + 1 HCLK cycle for          |  |
|            |          | write accesses, DTOP + 3 HCLK cycles for read accesses                |  |
|            |          | This field cannot be 0, and the minimum value is 1.                   |  |
| 7-4        |          | 0x0                                                                   |  |
| 3-0        | ADROP    | Duration of the first phase of write access (ADROP + $1 \text{ HCLK}$ |  |
|            |          | cycle)                                                                |  |

#### Mode D——Asynchronous access with extended address

Figure 18-12 Mode D Read Access





Note: A[15:1] is not outputted.

Figure 18-13 Mode D Write Access



Note: A[15:1] is not outputted.

The difference between Mode D and Mode 1 is the NADV toggling (the NOE toggling occurs after the



NADV toggling) and the independent read/write timings.

|  | Table 18-21 XMC_ | BK1CTRLx Bi | t Field ( | (Mode | D) |
|--|------------------|-------------|-----------|-------|----|
|--|------------------|-------------|-----------|-------|----|

| Bit Number | Bit Name  | Value Set                                                           |  |
|------------|-----------|---------------------------------------------------------------------|--|
| 31-16      |           | 0×0000                                                              |  |
| 15         | WAITASYNC | Set to 1 if the memory supports this feature. Otherwise, keep at 0. |  |
| 14         | TMGWREN   | 0x1                                                                 |  |
| 13-10      |           | 0×0                                                                 |  |
| 9          | WAITALV   | Meaningful only if the bit 15 is `1'.                               |  |
| 8          | BURSTEN   | 0x0                                                                 |  |
| 7          |           | -                                                                   |  |
| 6          | NOREN     | Depend on the memory                                                |  |
| 5-4        | BUSTYPE   | Set as needed                                                       |  |
| 3-2        | DEV       | Set as needed                                                       |  |
| 1          | MUXEN     | 0x0                                                                 |  |
| 0          | EN        | 0×1                                                                 |  |

#### Table 18-22 XMC\_BK1TMGx Bit Field (Mode D)

| Bit Number | Bit Name Value Set                                      |                                                                                                                        |
|------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| 31-30      |                                                         | 0x0                                                                                                                    |
| 29-28      | MODE                                                    | 0x3                                                                                                                    |
| 27-20      |                                                         | 0x000                                                                                                                  |
| 19-16      | INTVLOP Time between NEx high to NEx low (INTVLOP HCLK) |                                                                                                                        |
| 15-8       | DTOP                                                    | Duration of the second phase of read access (DTOP + 3 HCLK cycles) This field cannot be 0, and the minimum value is 1. |
| 7-4        | ADRHLD                                                  | Duration of the middle phase of read access (ADRHLD + 1 HCLK cycle)                                                    |
| 3-0        | ADROP                                                   | Duration of the first phase of read access (ADROP + 1 HCLK cycle)                                                      |

Table 18-23 XMC\_BK1TMGWRx Bit Field (Mode D)

Bit Number

Bit Name

Value Set



| 31-30 |         | 0×0                                                                                                                    |
|-------|---------|------------------------------------------------------------------------------------------------------------------------|
| 29-28 | MODE    | 0x3                                                                                                                    |
| 27-20 |         | 0x000                                                                                                                  |
| 19-16 | INTVLOP | Time between NEx high to NEx low (INTVLOP HCLK)                                                                        |
| 15-8  | DTOP    | Duration of the second phase of write access (DTOP + 1 HCLK cycle) This field cannot be 0, and the minimum value is 1. |
| 7-4   | ADRHLD  | Duration of the middle phase of write access (ADRHLD + 1 HCLK cycle)                                                   |
| 3-0   | ADROP   | Duration of the first phase of write access (ADROP + 1 HCLK cycle)                                                     |

#### Multiplexed mode——Address/data multiplexed NOR Flash asynchronous access

Figure 18-14 Multiplexed Read Access



Note: The bus turnaround delay (INTVLOP + 1) and the internal delay between 2 consecutive read accesses are partially overlapped, so INTVLOP  $\leq$  5 will not affect output timing.

Figure 18-15 Multiplexed Write Access





The difference between Multiplexed Mode and Mode D is that the lower 16-bit address occurs on the data bus.

| Table 18-24 XMC_ | BK1CTRLx | Bit Field | (Multiplexed | Mode) |
|------------------|----------|-----------|--------------|-------|
|                  |          |           | (            |       |

| Bit Number | Bit Name                                    | Value Set                                                           |  |
|------------|---------------------------------------------|---------------------------------------------------------------------|--|
| 31-16      |                                             | 0×0000                                                              |  |
| 15         | WAITASYNC                                   | Set to 1 if the memory supports this feature. Otherwise, keep at 0. |  |
| 14         | TMGWREN                                     | 0×0                                                                 |  |
| 13-10      |                                             | 0×0                                                                 |  |
| 9          | WAITALV                                     | Meaningful only if the bit 15 is `1'.                               |  |
| 8          | BURSTEN                                     | 0x0                                                                 |  |
| 7          |                                             | -                                                                   |  |
| 6          | NOREN                                       | 0x1                                                                 |  |
| 5-4        | BUSTYPE                                     | Set as needed                                                       |  |
| 3-2        | DEV                                         | 0x2 (NOR Flash)                                                     |  |
| 1          | MUXEN                                       | 0x1                                                                 |  |
| 0          | EN                                          | 0x1                                                                 |  |
| ango       | Hangzhou Vango Technologies, Inc. 707 / 782 |                                                                     |  |

| Table 18-25 XMC_BRITMGX BIT FIELD (MULTIPLEXED MODE) |          |                                                                                                                                                                               |
|------------------------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit Number                                           | Bit Name | Value Set                                                                                                                                                                     |
| 31-30                                                |          | 0×0                                                                                                                                                                           |
| 29-20                                                |          | 0×0                                                                                                                                                                           |
| 19-16                                                | INTVLOP  | Duration of the last phase of the access (INTVLOP + 1 HCLK cycle)                                                                                                             |
| 15-8                                                 | DTOP     | Duration of the second access phase, DTOP + 1 HCLK cycle for<br>write accesses, DTOP + 3 HCLK cycles for read accesses<br>This field cannot be 0, and the minimum value is 1. |
| 7-4                                                  | ADRHLD   | Duration of the middle phase of the access (ADRHLD + 1 HCLK cycle) This field cannot be 0, and the minimum value is 1.                                                        |
| 3-0                                                  | ADROP    | Duration of the first access phase (ADROP + 1 HCLK cycle).                                                                                                                    |

### Table 18-25 XMC BK1TMGy Bit Field (Multipleyed Mode)

### 18.3.2.5 Synchronous Transactions

According to different values of the parameter, CLKPSC, HCLK cycle is the multiple of memory clock, CLK.

NOR Flash memories specify a minimum time from NADV assertion to CLK high. To meet this constraint, XMC does not issue the clock to the memory during the first internal clock cycle of the synchronous access (before NADV assertion). This guarantees that the rising edge of the memory clock occurs in the middle of the NADV low pulse.

#### **Data latency versus NOR Flash latency**

The data latency is the number of cycles to wait before sampling the data. The DTSTBL value must be consistent with the latency value specified in the NOR Flash configuration register. XMC does not include the clock cycle when NADV is low in the data latency count.

Note: Some NOR Flash memories include the NADV LOW cycle in the data latency count, so the exact relation between the NOR Flash latency and XMC DTSTBL parameter can be either:

- NOR Flash latency = DTSTBL + 2; or
- NOR Flash latency = DTSTBL + 3

Some new memories assert a NWAIT signal at the latency phase. In such cases, DTSTBL can be set to its minimum value. As a result, XMC samples the NWAIT signal and waits long enough until the data are valid. After XMC detects that the memory exits latency phase, correct data are read.



Other memories do not assert NWAIT during latency. In this case, the latency for both XMC and the memory must be set as the same value; otherwise, correct data cannot be obtained, or valid data might be lost at the initial phase of the memory access.

#### Single-burst transfer

When the selected bank is configured in burst mode for synchronous accesses, if an AHB single-burst transaction is requested with 16-bit data, then XMC performs a burst transaction of length 1; if the AHB transfer is 32-bit, then XMC splits it as two 16-bit transfers, performs a burst transaction of length 2, and then de-assert the chip-select signal when the last data is strobed. When the last data transfer is completed, chip-select signal is withdrew.

Clearly, such a transfer is not the most efficient (compared to an asynchronous read). Nevertheless, a random asynchronous access will first require to reprogram the memory access mode, which also takes longer time.

#### Wait management

For synchronous NOR Flash memories, NWAIT should be evaluated after the programmed latency period (DTSTBL + 2 CLK clock cycles).

If NWAIT is detected as active (low level when WAITALV = 0, high level when WAITALV = 1), wait states are inserted by XMC until NWAIT is sensed inactive (high level when WAITALV = 0, low level when WAITALV = 1).

When NWAIT is inactive, the data is considered valid either immediately (WAITCFG = 1) or on the next clock edge (WAITCFG = 0).

During wait-state insertion via the NWAIT signal, the controller continues to send clock pulses to the memory, keeping the chip-select signal, outputting valid signals, and ignoring invalid data. There are two timing configurations for the NOR Flash NWAIT signal in burst mode:

- Flash memory asserts the NWAIT signal one data cycle before the wait state (Default after reset).
- Flash memory asserts the NWAIT signal at the wait state.

XMC supports these two NOR Flash wait state configurations on each chip select, by configuring the WAITCFG bit in the XMC\_BK1CTRLx registers.

Figure 18-16 Synchronous Multiplexed Read Mode- NOR and PSRAM (CRAM)





*Note: The NBL signal is not shown in* Figure 18-16; *NBL is high for NOR Flash, low for* PSRAM (CRAM).

Table 18-26 XMC\_BK1CTRLx Bit Field (Synchronous Mode)

| Bit Number | Bit Name   | Value Set                                                     |  |
|------------|------------|---------------------------------------------------------------|--|
| 31-20      |            | 0×0000                                                        |  |
| 19         | BURSTWRSYN | No effect in synchronous read mode                            |  |
| 18-16      | PGSIZE     | Set as needed (0x1 for CRAM 1.5)                              |  |
| 14         | TMGWREN    | 0×0                                                           |  |
| 15         |            | 0×0                                                           |  |
| 13         | WAITEN     | Set to 1 if the memory supports this feature. Otherwise, keep |  |
|            |            | at 0.                                                         |  |
| 12         | WREN       | No effect in synchronous read mode                            |  |
| 11         | WAITCFG    | Depend on the memory features                                 |  |
| 10         | BRSTSPLTEN | 0×0                                                           |  |
| 9          | WAITALV    | Depend on the memory features                                 |  |
| 8          | BURSTEN    | 0x1                                                           |  |



| 7   |         | 0x1                  |  |  |  |
|-----|---------|----------------------|--|--|--|
| 6   | NOREN   | Depend on the memory |  |  |  |
| 5-4 | BUSTYPE | Set as needed        |  |  |  |
| 3-2 | DEV     | 0x1 or 0x2           |  |  |  |
| 1   | MUXEN   | Set as needed        |  |  |  |
| 0   | EN      | 0x1                  |  |  |  |

Table 18-27 XMC\_BK1TMGx Bit Field (Synchronous Mode)

| Bit Number | Bit Name | Value Set                                          |
|------------|----------|----------------------------------------------------|
| 31-28      |          | 0x0                                                |
| 27-24      | DTSTBL   | Data hold time                                     |
| 23-20      | CLKPSC   | 0x0: Get CLK = HCLK (Not supported) 0x1: Get CLK = |
|            |          | 2xHCLK                                             |
| 19-16      | INTVLOP  | No effect                                          |
| 15-8       | DTOP     | No effect                                          |
| 7-4        | ADRHLD   | No effect                                          |
| 3-0        | ADROP    | No effect                                          |

Figure 18-17 Synchronous Multiplexed Write Mode- PSRAM (CRAM)





*Note: 1. The memory should issue the NWAIT signal one cycle before, and at the same* time WAITCFG should be configured as 0.

2. Byte Lane (NBL) outputs are not shown in Figure 18-17, they are held low while NEx is active.

| Table 18-28 XMC | _BK1CTRLx Bit Field | (Svnch | ronous Mode) |
|-----------------|---------------------|--------|--------------|
|                 |                     | (0)    |              |

| Bit Number | Bit Name   | Value Set                                                     |  |  |
|------------|------------|---------------------------------------------------------------|--|--|
| 31-20      |            | 0x0000                                                        |  |  |
| 19         | BURSTWRSYN | 0×1                                                           |  |  |
| 18-16      | PGSIZE     | Set as needed (0x1 for CRAM 1.5)                              |  |  |
| 15         |            | 0×0                                                           |  |  |
| 14         | TMGWREN    | 0×0                                                           |  |  |
| 13         | WAITEN     | Set to 1 if the memory supports this feature. Otherwise, keep |  |  |
|            |            | at 0.                                                         |  |  |
| 12         | WREN       | 0x1                                                           |  |  |
| 11         | WAITCFG    | 0×0                                                           |  |  |
| 10         | BRSTSPLTEN | 0×0                                                           |  |  |
| 9          | WAITALV    | Depend on the memory features                                 |  |  |
|            |            |                                                               |  |  |

| 8   | BURSTEN | No effect in synchronous write mode |  |  |  |
|-----|---------|-------------------------------------|--|--|--|
| 7   |         | 0x1                                 |  |  |  |
| 6   | NOREN   | Depend on the memory                |  |  |  |
| 5-4 | BUSTYPE | Set as needed                       |  |  |  |
| 3-2 | DEV     | 0x1                                 |  |  |  |
| 1   | MUXEN   | Set as needed                       |  |  |  |
| 0   | EN      | 0x1                                 |  |  |  |

Table 18-29 XMC\_BK1TMGx Bit Field (Synchronous Mode)

| Bit Number | Bit Name | Value Set                                              |  |
|------------|----------|--------------------------------------------------------|--|
| 31-28      | -        | 0×0                                                    |  |
| 27-24      | DTSTBL   | Data hold time                                         |  |
| 23-20      | CLKPSC   | 0x0: Get CLK = HCLK (Not supported) 0x1: Get CLK = 2 x |  |
|            |          | HCLK                                                   |  |
| 19-16      | INTVLOP  | Time between NEx high to NEx low (INTVLOP HCLK)        |  |
| 15-8       | DTOP     | No effect                                              |  |
| 7-4        | ADRHLD   | No effect                                              |  |
| 3-0        | ADROP    | No effect                                              |  |

## **18.3.3 NAND Flash Controller**

XMC can generate appropriate signal timings to drive the following types of devices:

• NAND Flash

— 8-bit

— 16-bit

NAND controller can control Bank 2.

The bank is configured by dedicated registers (Please refer to Section 18.4). The programmable memory

parameters include access timings and ECC configuration.

Table 18-30 Programmable NAND Access Parameter



| Parameter                   | Function                                                                                                                                | Access<br>Mode | Unit            | Min. | Max |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------------|------|-----|
| Memory setup<br>time        | Number of clock cycles (HCLK) to set up the address before the command assertion                                                        |                |                 | 1    | 256 |
| Memory wait<br>time         | Minimum duration (HCLK clock cycles) of the command assertion                                                                           | R/W            | AHB clock       | 1    | 255 |
| Memory hold<br>time         | Number of clock cycles (HCLK) to hold the<br>address after the command de-assertion; also the<br>data hold time in case of write access | R/W            | cycle<br>(HCLK) | 1    | 255 |
| Memory data<br>bus HiZ time | Number of clock cycles (HCLK) during which the<br>Data bus is kept at HiZ state after the start of a<br>write access                    | W              |                 | 0    | 255 |

## 18.3.3.1 External Memory Interface Signal

Table 18-31, Table 18-32, and Table 18-33 list the signals that are typically used to interface NAND Flash. Prefix "N" indicates that the associated signal is active low.

#### 8-bit NAND Flash

| XMC Signal Name | Direction | Function                                             |  |
|-----------------|-----------|------------------------------------------------------|--|
| A[17]           | 0         | NAND Flash address latch enable (ALE) signal         |  |
| A[16]           | 0         | NAND Flash command latch enable (CLE) signal         |  |
| D[7:0]          | I/O       | 8-bit multiplexed, bidirectional address/data bus    |  |
| NCE[2]          | 0         | Chip select                                          |  |
| NOE ( = NRE)    | 0         | Output enable (Memory signal name: read enable, NRE) |  |
| NWE             | 0         | Write enable                                         |  |
| NWAIT           | I         | NAND Flash ready/busy signal input to XMC            |  |

Table 18-31 8-bit NAND Flash

XMC can generate as many address cycles as needed; theoretically, there is no NAND access capacity limitation.

#### 16-bit NAND Flash

Table 18-32 16-bit NAND Flash



| XMC Signal Name | Direction | Function                                             |
|-----------------|-----------|------------------------------------------------------|
| A[17]           | 0         | NAND Flash address latch enable (ALE) signal         |
| A[16]           | 0         | NAND Flash command latch enable (CLE) signal         |
| D[15:0]         | I/O       | 16-bit multiplexed, bidirectional address/data bus   |
| NCE[2]          | 0         | Chip select                                          |
| NOE ( = NRE)    | 0         | Output enable (Memory signal name: read enable, NRE) |
| NWE             | 0         | Write enable                                         |
| NWAIT/INT       | Ι         | NAND Flash ready/busy signal input to XMC            |

XMC can generate as many address cycles as needed; theoretically, there is no NAND access capacity limitation.

# 18.3.3.2 NAND Flash Supported Memories and Transaction

Table 18-33 lists the supported memories, access modes, and transactions; NAND Flash Controller do not support the transactions in gray.

|                | Asynchronous | R   | 32               | 16<br>o Technolog   | Yes            | Split into two XMC accesses<br><b>715 / 782</b> |
|----------------|--------------|-----|------------------|---------------------|----------------|-------------------------------------------------|
| NAND           | Asynchronous | W   | 16               | 16                  | Yes            |                                                 |
| 16-bit<br>NAND | Asynchronous | R   | 16               | 16                  | Yes            |                                                 |
|                | Asynchronous | W   | 8                | 16                  | No             |                                                 |
|                | Asynchronous | R   | 8                | 16                  | Yes            |                                                 |
|                | Asynchronous | W   | 32               | 8                   | Yes            | Split into four XMC accesses                    |
|                | Asynchronous | R   | 32               | 8                   | Yes            | Split into four XMC accesses                    |
| NAND           | Asynchronous | W   | 16               | 8                   | Yes            | Split into two XMC accesses                     |
| 8-bit          | Asynchronous | R   | 16               | 8                   | Yes            | Split into two XMC accesses                     |
|                | Asynchronous | W   | 8                | 8                   | Yes            |                                                 |
|                | Asynchronous | R   | 8                | 8                   | Yes            |                                                 |
| Memory         | Mode         | R/W | AHB Data<br>Size | Memory<br>Data Size | Not<br>allowed | Comment                                         |
|                |              |     |                  |                     | Allowed/       |                                                 |

Table 18-33 Supported Memories and Transactions

|  | Asynchronous | W | 32 | 16 | Yes | Split into two XMC accesses |
|--|--------------|---|----|----|-----|-----------------------------|
|  |              |   |    |    |     | -                           |

### 18.3.3.3 NAND Flash Timing Diagram

NAND Flash memory bank is managed through a set of registers:

- Control register: XMC\_BK2CTRL
- Interrupt status register: XMC\_BK2STS
- ECC register: XMC\_BK2ECC
- Timing register for common memory space: XMC\_BK2TMGMEM
- Timing register for attribute memory space: XMC\_BK2TMGATT

Each timing configuration register contains three parameters used to define number of HCLK cycles for the three phases of NAND Flash access, plus one parameter that defines the timing during which XMC starts driving the data bus in a write access. Figure 18-18 shows the timing parameter definitions for common memory accesses; in attribute memory space access, timings is similar.





*Note: 1. NOE remains high (inactive) during write access. NWE remains high (inactive)* during read access.

2. NCE2 goes low as soon as NAND access is requested, and it remains low until a different memory bank is accessed.



### 18.3.3.4 NAND Flash Operation

As mentioned above, the command latch enable (CLE) and address latch enable (ALE) signals of the NAND Flash are driven by address signal lines of XMC. This means that, to send a command or an address to the NAND Flash, CPU has to perform a write access to a certain address in its memory space.

A typical read operation to the NAND Flash device includes the following steps:

1. According to the NAND Flash characteristics, program and enable the corresponding memory bank by configuring the XMC\_BK2CTRL and XMC\_BK2TMGMEM registers; for some devices, the XMC\_BK2TMGATT register also needs to be programmed (See <u>Section 18.3.3.5</u>). Bits to be configured include: BUSTYPE for the data bus width of the NAND Flash, DEV = 1, and WAITEN = 0 or 1; please refer to the timing configuration in <u>Section 18.4.2.3</u>.

2. CPU performs Flash command byte write in the common memory space (for example, 0x00 for Samsung NAND Flash); during the write strobe (low pulse on NWE), the CLE input of the NAND Flash is active (high level), so the written byte is interpreted as a command by the NAND Flash. Once the command is latched by the NAND Flash, it does not need to be written for the following page read operations.

3. CPU writes four bytes (three for devices with smaller capacity) in the common memory or attribute space as the start address (STARTAD) for a read operation. Take 64 Mb x 8 NAND Flash as an example, the writing sequence is STARTAD[7:0], STARTAD[15:8], STARTAD[23:16], and finally STARTAD[25:24]. During the write strobe (low pulse on NWE), the ALE input of the NAND Flash is active (high level), so the written bytes are interpreted as the start address for read operations. Using the attribute memory space allows XMC to generate different timings, which can be used to implement the prewait function needed by some the NAND Flash (Please refer to Section 18.3.3.5).

4. Before starting a new access (to the same or another memory bank), the controller waits for the NAND Flash to be ready (R/NB signal becomes high). While waiting, the controller keeps the NCE signal active (low).

5. The CPU can then perform byte read operations in the common memory space to read the NAND Flash page (data field and spare field) byte by byte.

6. Without any CPU command or address write operation, the next NAND Flash page can be read in one of the following three ways:



- Perform the operation in step 5
- Restart the operation in step 3 to access a new address
- Restart the operation in step 2 to access a new command

### 18.3.3.5 NAND Flash Prewait Functionality

Some NAND Flash devices require that the controller wait for the R/NB signal to go low after writing the last part of the address, as shown in Figure 18-19.

Figure 18-19 Access to Non "CE Don't Care" NAND Flash



Note: 1. CPU writes byte 0x00 at address 0x70010000.

2. CPU writes byte A7 ~ A0 at address 0x70020000.

3. CPU writes byte A15 ~ A8 at address 0x70020000.

4. CPU writes byte A23 ~ A16 at address 0x70020000.

5. CPU writes byte A25 ~ A24 at address 0x78020000: XMC performs a write access using

XMC\_BK2TMGATT timing definition, where TMGATT\_HLD  $\geq$ 7 (providing that (7 + 1) ×HCLK = 112)

ns > the max. of  $t_{WB}$ ). This guarantees that NCE remains low while R/NB goes from low to high. This requirement only applies

for "Non NCE don't care" NAND Flash.

When this functionality is needed, tWB timing can be guaranteed by programming the TMGMEM\_HLD value. However, in any following CPU read/write accesses to the NAND Flash memory, controller will



insert a hold delay of (TMGMEM\_HLD + 1) HCLK cycles between NWE signal rising edge and the next operation.

To overcome this timing constraint, the attribute memory space can be used by programming TMGATT\_HLD value to meet the  $t_{WB}$  timing, and leaving the TMGMEM\_HLD value at its minimum. Then, CPU must use the common memory space for all NAND Flash read and write accesses, except when writing the last address byte to the NAND Flash device, where CPU must write to the attribute memory space.

### 18.3.3.6 NAND Flash ECC Calculation

XMC NAND controller includes one error correction code computation hardware blocks in memory bank 2. It is used to reduce CPU workload when processing the error correction code by software. One register is associated with hardware ECC computation included in bank 2.

The error correction code (ECC) algorithm implemented in XMC can perform 1-bit error correction and 2-bit error detection per 256, 512, 1024, 2048, 4096, or 8192 bytes read or written to NAND Flash memory.

The ECC modules monitor the NAND Flash data bus and read/write signals (NCE and NWE) each time when the NAND Flash memory card is activated.

The operation of the function is as follows:

• When access to NAND Flash is made in bank 2, the data present on the D[15:0] bus is latched and used for ECC computation.

When access to NAND Flash occurs at any other address, the ECC logic does not perform any operation.
 Thus, write operations for defining NAND Flash commands or addresses are not taken into account for ECC computation.

Once the desired number of bytes is read from/ written to the NAND Flash, the XMC\_BK2ECC register must be read by software in order to retrieve the computed ECC value. Once read, the register is cleared by resetting the ECCEN bit to 0. Then, the ECCEN bit must be set to '1' in the XMC\_BK2CTRL register to enable a new ECC computation.

# **18.4 XMC Registers**

Table 18-34 XMC Registers Address Mapping



| Offset | Register Name | Reset Value | Description                                   |
|--------|---------------|-------------|-----------------------------------------------|
| 000h   | XMC_BK1CTRL1  | 0x000030DB  | SRAM/NOR Flash chip-select control register 1 |
| 004h   | XMC_BK1TMG1   | 0x0FFFFFFF  | SRAM/NOR Flash chip-select timing register 1  |
| 018h   | XMC_BK1CTRL4  | 0x000030D2  | SRAM/NOR Flash chip-select control register 4 |
| 01Ch   | XMC_BK1TMG4   | 0x0FFFFFFF  | SRAM/NOR Flash chip-select timing register 4  |
| 060h   | XMC_BK2CTRL   | 0x0000018   | NAND Flash control register 2                 |
| 064h   | XMC_BK2STS    | 0x00000040  | FIFO status and interrupt register 2          |
| 068h   | XMC_BK2TMGMEM | 0xFCFCFCFC  | Common memory space timing register 2         |
| 06Ch   | XMC_BK2TMGATT | 0xFCFCFCFC  | Attribute memory space timing register 2      |
| 074h   | XMC_BK2ECC    | 0x00000000  | ECC result register 2                         |
| 104h   | XMC_BK1TMGWR1 | 0x0FFFFFFF  | SRAM/NOR Flash write timing register 1        |
| 11Ch   | XMC_BK1TMGWR4 | 0x0FFFFFFF  | SRAM/NOR Flash write timing register 4        |
| 220h   | XMC_EXT1      | 0x0000808   | SRAM/NOR Additional timing register 1         |
| 22Ch   | XMC_EXT1      | 0x00000808  | SRAM/NOR Additional timing register 4         |

# 18.4.1 NOR Flash and PSRAM Controller Register

# 18.4.1.1 SRAM/NOR Flash Chip-select Control Register 1 and 4 (XMC\_BK1CTRL1 and 4)

Address offset: 0xA0000000 + 8 \* (x - 1), x = 1 and 4

Reset value: Bank1 is 0x000030DB, and Bank 4 is 0x000030D2.

This register contains the control information of each memory bank, which can be used for SRAM, ROM, asynchronous or burst transfer NOR Flash memories.

| Bit       | Name       | Туре | Description                                                                                                         |  |
|-----------|------------|------|---------------------------------------------------------------------------------------------------------------------|--|
| Bit 31:20 | -          | -    | Reserved                                                                                                            |  |
| Bit 19    | BURSTWRSYN | rw   | Write burst enable<br>For Cellular RAM, this bit enables the synchronous burst<br>protocol during write operations. |  |



|           |           |    | The enable bit of synchronous burst protocol for read accesses   |
|-----------|-----------|----|------------------------------------------------------------------|
|           |           |    | is the BURSTEN bit in the XMC_BK1CTRLx register.                 |
|           |           |    | 0: Write access is in asynchronous mode.                         |
|           |           |    | 1: Write access is in synchronous mode.                          |
|           |           |    | CRAM page size                                                   |
|           |           |    | These are used for Cellular RAM 1.5, which does not allow burst  |
|           |           |    | access to cross the address boundaries between pages. When       |
|           |           |    | these bits are configured, XMC controller splits to burst access |
|           |           |    | automatically once the memory page size is reached               |
| Bit 18:16 | DOCIZE    |    | (Please refer to memory datasheet for page size).                |
| Dit 10.10 | PGSIZE    | rw | 000: No burst split when crossing page boundary, which is the    |
|           |           |    | default after reset.                                             |
|           |           |    | 001: 128 bytes                                                   |
|           |           |    | 010: 256 bytes                                                   |
|           |           |    | 011: 512 bytes                                                   |
|           |           |    | 100: 1024 bytes Others: Reserved                                 |
|           | WAITASYNC | rw | Wait signal during asynchronous transfers                        |
|           |           |    | This bit enables/disables XMC to use the wait signal, even       |
|           |           |    | during an asynchronous protocol.                                 |
| Bit 15    |           |    | 0: The NWAIT signal is not taken into account when running an    |
|           |           |    | asynchronous protocol (default after reset).                     |
|           |           |    | 1: The NWAIT signal is taken into account when running an        |
|           |           |    | asynchronous protocol.                                           |
|           |           |    | Extended mode enable                                             |
|           |           |    | This bit enables XMC to program the XMC_BK1TMGWR register,       |
|           |           |    | which allows different timings for read and write operations.    |
| Bit 14    | TMGWREN   | rw | 0: The XMC_BK1TMGWR register is not used, which is the           |
|           |           |    | default state after reset.                                       |
|           |           |    | 1: XMC uses the XMC_BK1TMGWR register.                           |
|           | WAITEN    |    | Wait enable bit                                                  |
| Bit 13    |           | rw | This bit enables/disables wait-state insertion via the NWAIT     |
|           |           |    | 1                                                                |



|        |            |    | signal in synchronous mode.                                     |
|--------|------------|----|-----------------------------------------------------------------|
|        |            |    | 0: The NWAIT signal is disabled, and the NWAIT signal wait      |
|        |            |    | state insertion will not be                                     |
|        |            |    | detected after the programmed Flash latency period.             |
|        |            |    | 1: The NWAIT signal is enabled, and wait states are inserted    |
|        |            |    | according to the NWAIT signal after the programmed Flash        |
|        |            |    | latency period; this is the default state after reset.          |
|        |            |    | Write enable bit                                                |
|        |            |    | This bit indicates whether XMC write accesses in the bank are   |
|        |            |    | enabled/disabled.                                               |
| Bit 12 | WREN       | rw | 0: XMC write operations in the bank are disabled; otherwise, an |
|        |            |    | AHB error is reported,                                          |
|        |            |    | 1: XMC write operations in the bank are enabled; this is the    |
|        |            |    | default state after reset.                                      |
|        | WAITCFG    | rw | Wait timing configuration                                       |
|        |            |    | When the Flash memory in burst mode, the NWAIT signal           |
|        |            |    | indicates whether the data from the memory are valid, or        |
|        |            |    | whether a wait state should be inserted. This configuration bit |
|        |            |    | determines if NWAIT is asserted one clock cycle before the wait |
| Bit 11 |            |    | state or at the wait state:                                     |
|        |            |    | 0: NWAIT signal is active one data cycle before the wait state; |
|        |            |    | the default state after reset.                                  |
|        |            |    | 1: NWAIT signal is active at the wait state (Not applicable for |
|        |            |    | Cellular RAM).                                                  |
|        |            |    |                                                                 |
|        |            | rw | Wrapped burst mode support                                      |
| Bit 10 | BRSTSPLTEN |    | This bit defines whether the controller will split an AHB burst |
|        |            |    | wrap access into two linear accesses. It is valid only when     |
|        |            |    | accessing memories in burst mode.                               |
|        |            |    | 0: Direct wrapped burst is disabled; this is the default state  |
|        |            |    | after reset.                                                    |
|        |            |    | 1: Direct wrapped burst is enabled.                             |



| Mango   |         |    | zhou Vango Technologies, Inc. 723 / 78                            |
|---------|---------|----|-------------------------------------------------------------------|
| Bit 1   | MUXEN   | rw | Address/data multiplexing enable bit                              |
|         |         |    | 11: Reserved                                                      |
|         |         |    | 10: NOR Flash (Default after reset for Bank 1)                    |
| Bit 3:2 | DEV     | rw | 01: PSRAM (Cellular RAM: CRAM)                                    |
|         |         |    | 00: SRAM (Default after reset for Bank 4)                         |
|         |         |    | The bits define the type of external memory:                      |
|         |         |    | Memory type                                                       |
|         |         |    | 11: Reserved; do not use.                                         |
|         |         |    | 10: Reserved; do not use.                                         |
| Bit 5:4 | BUSTYPE | rw | 00: 8 bits<br>01: 16 bits (Default after reset)                   |
|         | BUCTYDE | -  | for all types of memories.                                        |
|         |         |    | This bit defines the external memory device width, and is valid   |
|         |         |    | Memory data bus width                                             |
|         |         |    | 1: NOR Flash memory access is enabled.                            |
|         |         |    | 0: NOR Flash memory access is disabled.                           |
| Bit 6   | NOREN   | rw | This bit enables NOR Flash memory access operations.              |
|         |         |    | Flash access enable                                               |
| Bit 7   | -       | -  | Reserved                                                          |
|         |         |    | 1: Burst mode is enabled.                                         |
|         |         |    | 0: Burst mode is disabled; this is the default state after reset. |
|         |         |    | operating in burst mode.                                          |
| Bit 8   | BURSTEN | rw | memory. It is valid only for synchronous Flash memories           |
|         |         |    | This bit enables/disables burst mode accesses to the Flash        |
|         |         |    | Burst enable bit                                                  |
|         |         |    | 1: NWAIT signal is active high.                                   |
|         |         |    | reset.                                                            |
| Bit 9   | WAITALV | rw | 0: NWAIT signal is active low; this is the default state after    |
|         |         |    | is valid only when accessing the memory in burst mode:            |
|         |         |    | This bit defines the polarity of the wait signal from memory; if  |
|         |         |    |                                                                   |

|       |    |    | <ul> <li>When this bit is set, the lower 16 bits of the address/data</li> <li>values are multiplexed on the data bus; this bit is valid only</li> <li>with NOR and PSRAM memories:</li> <li>0: Address/data is not multiplexed.</li> <li>1: Address/data is multiplexed on data bus; this is the default</li> <li>state after reset.</li> </ul> |
|-------|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 0 | EN | rw | Memory bank enable bit<br>This bit enables the memory bank. After reset, bank 1 is<br>enabled, and all other memories are disabled. Accessing a<br>disabled bank causes an ERROR on AHB bus.<br>0: The corresponding memory bank is disabled.<br>1: The corresponding memory bank is enabled.                                                   |

## 18.4.1.2 SRAM/NOR Flash Chip-select Timing Register 1 and 4 (XMC\_BK1TMG1 and 4)

Address offset:  $0xA0000000 + 0x04 + 8^{*} (x-1), x = 1 \text{ and } 4$ 

Reset value: 0x0FFFFFFF

This register contains the control information of each memory bank used for SRAM, ROM, and NOR Flash memories. If the TMGWREN bit is set in the XMC\_BK1CTRLx register, then there will be two timing registers available: one to configure read accesses (this register), and the other to configure write accesses (the XMC\_BK1TMGWRx register).

| Bit       | Name | Туре | Description                                                                                                                                                                                                      |
|-----------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:30 | -    | -    | Reserved                                                                                                                                                                                                         |
| Bit 29:28 | MODE | rw   | Access mode<br>The 2 bits define asynchronous access mode. They only have<br>effects when the TMGWREN bit is set in the XMC_BK1CTRLx<br>register.<br>00: Access mode A<br>01: Access mode B<br>10: Access mode C |



|           |              |    | 11: Access mode D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|--------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 27:24 | DTSTBL(Note) | rw | Data latency (for synchronous burst NOR Flash)<br>For synchronous NOR Flash memory with burst mode enabled,<br>it is required to define the number of memory clock cycles to<br>wait before accessing the first data. This timing parameter is<br>not expressed in HCLK periods, but in Flash clock periods (CLK).<br>In asynchronous NOR Flash, SRAM, or ROM access, this value<br>has no effect. In case of CRAM, this field must be set to 0.<br>0000: Data latency of 2 CLK clock cycles for first data access<br><br>1111: Data latency of 17 CLK clock cycles for first data access<br>(Default value after reset) |
| Bit 23:20 | CLKPSC       | rw | Clock divide ratio (for CLK signal)<br>This bit field defines the period of CLK clock output signal,<br>expressed in the number of HCLK cycles:<br>0000: Reserved<br>0001: 1 CLK cycle = 2 HCLK cycles<br>0010: 1 CLK cycle = 3 HCLK cycles<br><br>1111: 1 CLK cycle = 16 HCLK cycles (Default value after reset)<br>In asynchronous NOR Flash, SRAM, or ROM accesses, this value<br>has not effect.                                                                                                                                                                                                                     |
| Bit 19:16 | INTVLOP      | rw | Bus turnaround phase duration<br>These bits define the delay time on the bus after a read access<br>(only used for the muxed mode of NOR Flash access). After a<br>read access, the controller needs to issue the address for the<br>next operation on data bus, and this delay is used to avoid bus<br>conflicts. If the extended memory does not include muxed<br>mode memory of the bus, or the slowest memory can restore<br>data bus to HiZ state within 6 HCLK clock periods, this<br>parameter can be set as its minimum.<br>0000: Bus turnaround phase duration = 1 HCLK clock cycle                             |



|         |        |    | 11111111: DTOP phase duration = 256 HCLK clock cycles<br>(Default value after reset) For each memory type and access |
|---------|--------|----|----------------------------------------------------------------------------------------------------------------------|
|         |        |    | mode data-phase duration, please refer to the corresponding                                                          |
|         |        |    | figures (Figure 18-3 ~ Figure 18-15).                                                                                |
|         |        |    | For example:<br>Mode 1, read access, $DTOP = 1$ ; $Data-phase duration = DTOP + 3$                                   |
|         |        |    | Mode 1, read access, DTOP = 1: Data-phase duration = DTOP + 3<br>= 4 HCLK clock cycles                               |
|         |        |    | Address-hold phase duration                                                                                          |
|         |        |    | These bits define the duration of the address hold phase (Please                                                     |
|         |        |    | refer to Figure 18-13_~ Figure 18-15) used in SRAM, ROM, and                                                         |
|         |        |    | asynchronous muxed mode accesses of NOR Flash:                                                                       |
|         |        |    | 0000: Reserved                                                                                                       |
| Bit 7:4 | ADRHLD | rw | 0001: ADRHLD phase duration = 2 HCLK clock cycles                                                                    |
|         |        |    | 0010: ADRHLD phase duration = 3 HCLK clock cycles                                                                    |
|         |        |    |                                                                                                                      |
|         |        |    | 1111: ADRHLD phase duration = 16 HCLK clock cycles (Default                                                          |
|         |        |    | value after reset)                                                                                                   |
|         |        |    | Note: In synchronous accesses, this value has no effect. The                                                         |
|         |        |    | address hold phase duration is always 1 memory clock period.                                                         |
| Bit 3:0 | ADROP  | rw | Address setup phase duration                                                                                         |
|         |        |    | These bits define the duration of the address setup phase                                                            |

|  | (Please refer to Figure 18-3_ $\sim$ Figure 18-15) used in SRAM, |
|--|------------------------------------------------------------------|
|  | ROM, asynchronous muxed mode accesses of NOR Flash:              |
|  | 0000: ADROP setup phase duration = 1 HCLK clock cycle            |
|  |                                                                  |
|  | 1111: ADROP setup phase duration = 16 HCLK clock cycles          |
|  | (Default value after reset) For each access mode address setup   |
|  | phase duration, please refer to the corresponding figures        |
|  | (Figure 18-3 ~ Figure 18-15).                                    |
|  | For example: Mode 2, read access, ADROP = 1: Address setup       |
|  | phase duration = ADROP + 1 = 2 HCLK clock cycles                 |
|  | Note: In synchronous accesses, this value has no effect. The     |
|  | address setup phase duration is always 1 memory clock period.    |

*Note: PSRAM (CRAM) has variable hold latency due to internal refresh. Therefore, these* memories will issue the NWAIT signal at the whole latency phase to prolong the latency as needed.

With PSRAM (CRAM) in use, the DTSTBL field must be set to 0, so that XMC can exit its latency phase in time, start sampling NWAIT issued from the memory, and then begin to read or write when the memory is ready.

This method can also be used for the latest synchronous Flash memories, which can issue the NWAIT signal; please refer to the corresponding Flash Memory manual for more detailed information.

## 18.4.1.3 SRAM/NOR Flash Write Timing Register 1 and 4 (XMC\_BK1TMGWR1 and 4)

Address offset: 0xA0000000 + 0x104 + 8\* (x - 1), x = 1 and 4

Reset value: 0x0FFFFFFF

This register contains the control information of each memory bank used for SRAM, ROM, and NOR Flash memories. If the TMGWREN bit is set in the XMC\_BK1CTRLx register, then this register is used for write accesses.

| Bit        | Name | Туре | Description                   |           |
|------------|------|------|-------------------------------|-----------|
| Bit 31:30  | -    | -    | Reserved                      |           |
| Bit 29:28  | MODE | rw   | Access mode                   |           |
| Hango Hang |      | Hang | zhou Vango Technologies, Inc. | 727 / 782 |

|           |         |    | The 2 bits define asynchronous access mode. They only have        |
|-----------|---------|----|-------------------------------------------------------------------|
|           |         |    | effects when the TMGWREN bit is set in the XMC_BK1CTRLx           |
|           |         |    | register.                                                         |
|           |         |    | 00: Access mode A                                                 |
|           |         |    | 01: Access mode B                                                 |
|           |         |    | 10: Access mode C                                                 |
|           |         |    | 11: Access mode D                                                 |
| Bit 27:20 | -       | -  | Reserved                                                          |
|           |         |    | Bus turnaround phase duration                                     |
|           |         |    | These bits define the delay time on the bus after a read access   |
|           |         |    | (only used for the muxed mode of NOR Flash access). After a       |
|           |         |    | read access, the controller needs to issue the address for the    |
|           | INTVLOP |    | next operation on data bus, and this delay is used to avoid bus   |
|           |         | rw | conflicts. If the extended memory does not include muxed          |
| Bit 19:16 |         |    | mode memory of the bus, or the slowest memory can restore         |
|           |         |    | data bus to HiZ state within 6 HCLK clock periods, this           |
|           |         |    | parameter can be set as its minimum.                              |
|           |         |    | 0000: Bus turnaround phase duration = 1 HCLK clock cycle          |
|           |         |    |                                                                   |
|           |         |    | 1111: Bus turnaround phase duration = 16 HCLK clock cycles        |
|           |         |    | (Default value after reset)                                       |
|           |         |    | Data-phase duration                                               |
|           |         |    | These bits define the duration of the data phase (Please refer to |
|           |         |    | Figure 18-3 ~ Figure 18-15) used in SRAM, ROM, asynchronous       |
|           |         |    | muxed mode accesses of NOR Flash:                                 |
|           |         |    | 0000000: Reserved                                                 |
| Bit 15:8  | DTOP    | rw | 00000001: DTOP phase duration = 2 HCLK clock cycles               |
|           |         |    | 00000010: DTOP phase duration = 3 HCLK clock cycles               |
|           |         |    | · · · · · · · · · · · · · · · · · · ·                             |
|           |         |    | 11111111: DTOP phase duration = 256 HCLK clock cycles             |
|           |         |    | (Default value after reset)                                       |
|           |         |    |                                                                   |



|         |        |      | Address-hold phase duration                                        |
|---------|--------|------|--------------------------------------------------------------------|
|         |        |      | These bits define the duration of the address hold phase (Please   |
|         |        |      | refer to Figure 18-12_~ Figure 18-15) used in SRAM, ROM,           |
|         |        |      | asynchronous muxed mode accesses of NOR Flash:                     |
|         |        |      | 0000: Reserved                                                     |
|         | ADRHLD | F14/ | 0001: ADRHLD phase duration = 2 HCLK clock cycles                  |
| Bit 7:4 | ADRILD | rw   | 0010: ADRHLD phase duration = 3 HCLK clock cycles                  |
|         |        |      |                                                                    |
|         |        |      | 1111: ADRHLD phase duration = 16 HCLK clock cycles (Default        |
|         |        |      | value after reset)                                                 |
|         |        |      | Note: In synchronous accesses, this value has no effect. The       |
|         |        |      | address hold phase duration is always 1 memory clock period.       |
|         |        |      | Address setup phase duration                                       |
|         | ADROP  |      | These bits define the duration of the address setup phase with     |
|         |        | rw   | HCLK cycles (Please refer to Figure 18-3 $\sim$ Figure 18-15) used |
|         |        |      | in SRAM, ROM, asynchronous muxed mode accesses of NOR              |
|         |        |      | Flash:                                                             |
| Bit 3:0 |        |      | 0000: ADROP setup phase duration = 1 HCLK clock cycle              |
|         |        |      |                                                                    |
|         |        |      | 1111: ADROP setup phase duration = 16 HCLK clock cycles            |
|         |        |      | (Default value after reset)                                        |
|         |        |      | Note: In synchronous accesses, this value has no effect. The       |
|         |        |      | address setup phase duration is always 1 memory clock period.      |

## 18.4.1.4 SRAM/NOR Additional Timing Register 1 and 4 (XMC\_EXT1 and 4)

Address offset: 0xA0000000 + 0x220 + 4\*(x-1), x = 1 and 4

Reset value: 0x0000808

This register includes the control information of each memory bank, and can be used for SRAM, ROM, and NOR Flash memory.



| Bit       | Name        | Туре | Description                                                                                                                                                                                                                                                                                                                                                                     |
|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | -           | -    | Reserved                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 15:8  | BURSTURNR2R | rw   | Bus turnaround phase for consecutive read duration Define bus<br>turnaround phase for consecutive read duration<br>00000000: Consecutive read interval is 1 HCLK cycle.<br>00000001: Consecutive read interval is 2 HCLK cycles.<br><br>00001000: Consecutive read interval is 9 HCLK cycles (Default).<br><br>11111111: Consecutive read interval is 256 HCLK cycles.          |
| Bit 7:0   | BURSTURNW2W | rw   | Bus turnaround phase for consecutive write duration Define bus<br>turnaround phase for consecutive write duration<br>00000000: Consecutive write interval is 1 HCLK cycle.<br>00000001: Consecutive write interval is 2 HCLK cycles.<br><br>00001000: Consecutive write interval is 9 HCLK cycles<br>(Default).<br><br>11111111: Consecutive write interval is 256 HCLK cycles. |

#### **18.4.2 NAND Flash Controller Register**

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

#### 18.4.2.1 NAND Flash Control Register 2 (XMC\_BK2CTRL)

Address offset:  $0xA0000000 + 0x40 + 0x20^* (x - 1), x = 2$ 

Reset value: 0x0000018

| Bit        | Name      | Туре | Description                                                    |           |
|------------|-----------|------|----------------------------------------------------------------|-----------|
| Bit 31:20  | -         | -    | Reserved                                                       |           |
| Bit 19:17  | ECCPGSIZE | rw   | ECC page size<br>These bits define the extended ECC page size: |           |
| Hango Hang |           | Hang | zhou Vango Technologies, Inc.                                  | 730 / 782 |

| Bit 16:13DLYARA<br>A<br>B<br>CC<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<                                                                                                                                                                                                                                                                                                                                                     | -         |         |    |                                                                     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|----|---------------------------------------------------------------------|
| Bit 16:13DurantLet one and the second  |           |         |    | 000: 256 bytes                                                      |
| Bit 16:13DLYARALE to RE delay<br>These bits set the time from ALE low to RE low in number of<br>AHB clock cycles (HCLK).<br>Time: t_ar = (DLYAR + SET + 4) × THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYARR<br>A<br>CLE to RE delay<br>Time: t_cr = (DLYCR + SET + 4) × THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRrwCLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) × THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycles<br>Note: According to different address spaces, SET is<br>TIMGHE_STP or TMGATT_STP.Bit 12:9DLYCRrwELE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) × THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TIMGHE_STP or TMGATT_STP.Bit 8:7ReservedBit 6:1ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |         |    | 001: 512 bytes                                                      |
| InitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitialInitial <td< td=""><td></td><td></td><td></td><td>010: 1024 bytes</td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |         |    | 010: 1024 bytes                                                     |
| Initial StateInitial StateInitial StateBit 16:13LevelALE to RE delay<br>These bits set the time from ALE low to RE low in number of<br>AHB clock cycles (HCLK).<br>Time: t_ar = (DLYAR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRRCLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRRCLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwThese bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |         |    | 011: 2048 bytes                                                     |
| Bit 16:13DLYARALE to RE delay<br>These bits set the time from ALE low to RE low in number of<br>AHB clock cycles (HCLK).<br>Time: t_ar = (DLYAR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRrwCLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRrwCLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwThese bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |         |    | 100: 4096 bytes                                                     |
| Bit 16:13DLYARImage: Arrow and the arr |           |         |    | 101: 8192 bytes                                                     |
| Bit 16:13DLYARAHB clock cycles (HCLK).<br>Time: t_ar = (DLYAR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRCLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycles<br>Note: According to different address spaces, SET is<br>TIMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRrwCLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |           |         |    | ALE to RE delay                                                     |
| Bit 16:13DLYARTime: t_ar = (DLYAR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRR<br>CLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7Bit 6:ECCENrwBit 5:4BUSTYPErwBit 5:4BUSTYPErwThese bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |         |    | These bits set the time from ALE low to RE low in number of         |
| Bit 16:13DLYARrwHCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRCLE to RE delay<br>Time: t_Clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRrwCLE to RE delay<br>Time: t_Clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |         |    | AHB clock cycles (HCLK).                                            |
| Bit 16:13DLYARrw0000: 1 HCLK cycle (Default value)1111: 16 HCLK cyclesNote: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRRBit 12:9DLYCRrwBit 8:7Bit 8:7-ReservedBit 6ECCENrwBit 5:4BUSTYPErwBit 5:4BUSTYPErwTYPETecc bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |         |    | Time: $t_ar = (DLYAR + SET + 4) \times THCLK$ , where THCLK is the  |
| Bit 12:9DLYCRDLYCRCLE to RE delay<br>Time: t_Clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK cycles (Default value)<br><br>1111: 16 HCLK cycle (Default value)<br>Time: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus widthBit 5:4BUSTYPErwThese bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           | DIVAD   |    | HCLK clock period.                                                  |
| Bit 12:9DLYCRImage: Clear of the second secon | Bit 16:13 | DLYAR   | rw | 0000: 1 HCLK cycle (Default value)                                  |
| Image: Bit 12:9DLYCRNote: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRRCLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) × THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           |         |    |                                                                     |
| Image: heat stateImage: heat stateTMGMEM_STP or TMGATT_STP.Bit 12:9DLYCRCLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7Bit 8:7-ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |         |    | 1111: 16 HCLK cycles                                                |
| Bit 12:9DLYCRCLE to RE delay<br>Time: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |         |    | Note: According to different address spaces, SET is                 |
| Bit 12:9DLYCRTime: t_clr = (DLYCR + SET + 4) x THCLK, where THCLK is the<br>HCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7Bit 8:7-ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           |         |    | TMGMEM_STP or TMGATT_STP.                                           |
| Bit 12:9DLYCRrwHCLK clock period.<br>0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |         |    | CLE to RE delay                                                     |
| Bit 12:9DLYCRrw0000: 1 HCLK cycle (Default value)<br><br>1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |         |    | Time: $t_clr = (DLYCR + SET + 4) \times THCLK$ , where THCLK is the |
| Bit 12:9DLYCRrw1111: 16 HCLK cycles<br>Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7Bit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | DLYCR   | rw | HCLK clock period.                                                  |
| Bit 5:4BUSTYPErwImage: Section of the           |           |         |    | 0000: 1 HCLK cycle (Default value)                                  |
| Note: According to different address spaces, SET is<br>TMGMEM_STP or TMGATT_STP.Bit 8:7Bit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Bit 12:9  |         |    |                                                                     |
| Image: Bit 8:7ReservedBit 6ECCENrwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |         |    | 1111: 16 HCLK cycles                                                |
| Bit 8:7       -       Reserved         Bit 6       ECCEN       rw       ECC computation logic enable bit         0: ECC logic is disabled and reset (Default after reset).       1: ECC logic is enabled.         Bit 5:4       BUSTYPE       rw       Databus width         These bits define the external NAND Flash data bus width.       These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |         |    | Note: According to different address spaces, SET is                 |
| Bit 6ECCENFwECC computation logic enable bit<br>0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |         |    | TMGMEM_STP or TMGATT_STP.                                           |
| Bit 6ECCENrw0: ECC logic is disabled and reset (Default after reset).<br>1: ECC logic is enabled.Bit 5:4BUSTYPErwDatabus width<br>These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Bit 8:7   | -       | -  | Reserved                                                            |
| Bit 5:4     BUSTYPE     rw     These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |         |    | ECC computation logic enable bit                                    |
| Bit 5:4     BUSTYPE     rw     Databus width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Bit 6     | ECCEN   | rw | 0: ECC logic is disabled and reset (Default after reset).           |
| Bit 5:4 BUSTYPE rw These bits define the external NAND Flash data bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |           |         |    | 1: ECC logic is enabled.                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |         |    | Databus width                                                       |
| 00: 8 bits (Default value after reset)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Bit 5:4   | BUSTYPE | rw | These bits define the external NAND Flash data bus width.           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |         |    | 00: 8 bits (Default value after reset)                              |



|       |        |    | 01: 16 bits<br>10: Reserved; do not use.<br>11: Reserved; do not use.                                                                                                                                                                                        |  |
|-------|--------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 3 | DEV    | rw | Memory type<br>This bit defines the type of device attached to the corresponding<br>memory bank.<br>0: Reserved<br>1: NAND Flash (Default value after reset)                                                                                                 |  |
| Bit 2 | EN     | rw | NAND Flash memory bank enable bit<br>This bit enables the memory bank. Accessing a disabled<br>memory bank causes an ERROR on AHB bus<br>0: The corresponding memory bank is disabled (Default after<br>reset). 1: The corresponding memory bank is enabled. |  |
| Bit 1 | WAITEN | rw | Wait feature enable bit<br>This bit enables NAND Flash memory bank wait function.<br>0: Wait function is disabled (Default value after reset).<br>1: Wait function is enabled.                                                                               |  |
| Bit 0 | -      | -  | Reserved                                                                                                                                                                                                                                                     |  |

## 18.4.2.2 FIFO Status and Interrupt Register 2 (XMC\_BK2STS)

Address offset:  $0xA0000000 + 0x44 + 0x20^* (x - 1), x = 2$ 

Reset value: 0x0000040

This register contains information about FIFO status and interrupt. XMC has a FIFO used to store up to 16 words of data from the AHB when writing to memories.

This function helps to free AHB while XMC is draining its FIFO into the memory.

For ECC purposes, this register has one bit that indicates the FIFO status. The ECC is calculated while the data are written to the memory; hence, in order to read the correct ECC value, the software must wait until the FIFO is empty.



| Bit      | Name  | Туре | Description                                                                                                                                                        |  |
|----------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 31:7 | -     | -    | Reserved                                                                                                                                                           |  |
| Bit 6    | FIFOE | rw   | FIFO empty<br>Read-only bit, indicating FIFO status<br>0: FIFO is not empty.<br>1: FIFO is empty.                                                                  |  |
| Bit 5    | IFEN  | rw   | Interrupt falling edge detection enable bit<br>0: Interrupt falling edge detection request is disabled.<br>1: Interrupt falling edge detection request is enabled. |  |
| Bit 4    | IHLEN | rw   | Interrupt high-level detection enable bit<br>0: Interrupt high-level detection request is disabled.<br>1: Interrupt high-level detection request is enabled.       |  |
| Bit 3    | IREN  | rw   | Interrupt rising edge detection enable bit<br>0: Interrupt rising edge detection request is disabled.<br>1: Interrupt rising edge detection request is enabled.    |  |
| Bit 2    | IFF   | rw   | Interrupt falling edge status<br>This bit is set by hardware and cleared by software.<br>0: No interrupt falling edge occurs.<br>1: Interrupt falling edge occurs. |  |
| Bit 1    | IHLF  | rw   | Interrupt high-level status<br>This bit is set by hardware and cleared by software.<br>0: No interrupt high-level occurs.<br>1: Interrupt high-level occurs.       |  |
| Bit 0    | IRF   | rw   | Interrupt rising edge status<br>This bit is set by hardware and cleared by software.<br>0: No interrupt rising edge occurs.<br>1: Interrupt rising edge occurs.    |  |



## 18.4.2.3 Common Memory Space Timing Register 2 (XMC\_BK2TMGMEM)

Address offset:  $0 \times A0000000 + 0 \times 48 + 0 \times 20^* (x - 1), x = 2$ 

Reset value: 0xFCFCFCFC

Each XMC\_BK2 register contains the timing information for NAND Flash memory bank 2. The parameters are used for accesses to the NAND Flash command, address, and data read/write access.

| Bit       | Name  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:24 | WRSTP | rw   | Common memory databus HiZ time<br>After the start of a NAND Flash write access to common<br>memory space, databus needs to be kept in HiZ for a period of<br>time. This parameter defines the time during which the databus<br>is kept in HiZ in the number of HCLK clock cycles (+ 1 for NAND<br>types). This parameter is only valid for write transactions:<br>00000000: (0x00) NAND Flash is 1 HCLK cycle.<br><br>11111111: (0xFF) NAND Flash is 256 HCLK cycles. |
| Bit 23:16 | HLD   | rw   | Common memory hold time<br>For NAND Flash read/write accesses to the common memory<br>space, these bits define the hold time of address signal (data<br>signal for write access) after command is sent (NWE and NOE<br>become high) in HCLK clock cycle number.<br>00000000: Reserved<br>00000001: 1 HCLK cycle<br><br>11111111: 255 HCLK cycles                                                                                                                      |
| Bit 15:8  | OP    | rw   | Common memory wait time<br>For NAND Flash read/write accesses to the common memory<br>space, these bits define the minimum time of command hold<br>(NWE and NOE are low) in HCLK clock cycle number (+ 1). The                                                                                                                                                                                                                                                        |



|         |     |    | duration for command assertion is extended if the wait signal |
|---------|-----|----|---------------------------------------------------------------|
|         |     |    | (NWAIT) is active (low) at the end of the programmed value of |
|         |     |    |                                                               |
|         |     |    | HCLK.                                                         |
|         |     |    | 0000000: Reserved                                             |
|         |     |    | 0000001: 1 HCLK cycle (+ wait cycle introduced by             |
|         |     |    | deasserting NWAIT)                                            |
|         |     |    |                                                               |
|         |     |    | 11111111: 255 HCLK cycles (+ wait cycle introduced by         |
|         |     |    | deasserting NWAIT from Card)                                  |
|         |     |    | Common memory setup time                                      |
|         |     | rw | For NAND Flash read/write accesses to the common memory       |
|         |     |    | space, these bits define address signal setup time before     |
|         | STP |    | command assertion (NW E and NOE go low) in HCLK clock cycle   |
| Bit 7:0 | 517 |    | number (+ 2 in NAND Flash operation).                         |
|         |     |    | 00000000: NAND Flash is 2 HCLK cycles.                        |
|         |     |    |                                                               |
|         |     |    | 11111111: NAND Flash is 257 HCLK cycles.                      |

## 18.4.2.4 Attribute Memory Space Timing Register 2 (XMC\_BK2TMGATT)

Address offset:  $0xA0000000 + 0x4C + 0x20^* (x - 1), x = 2$ 

Reset value: 0xFCFCFCFC

Each XMC\_BK2TMGATT read/write register contains the timing information for NAND Flash memory bank x. The parameters are used when the timing of last address write access of the NAND Flash is different from other operations (For more information about ready/busy management, please refer to <u>Section</u> <u>19.3.3.5</u>).

| Bit       | Name  | Туре | Description                                                   |  |
|-----------|-------|------|---------------------------------------------------------------|--|
|           |       |      | Attribute memory databus HiZ time                             |  |
| Bit 31:24 | WRSTP | rw   | After the start of a NAND Flash write access to attribute     |  |
|           |       |      | memory space, databus needs to be kept in HiZ for a period of |  |



|           |     | 1  |                                                                |
|-----------|-----|----|----------------------------------------------------------------|
|           |     |    | time. This parameter defines the time during which the databus |
|           |     |    | is kept in HiZ in the number of HCLK clock cycles. This        |
|           |     |    | parameter is only valid for write transactions:                |
|           |     |    | 00000000: 0 HCLK cycles                                        |
|           |     |    |                                                                |
|           |     |    | 11111111: 255 HCLK cycles (Default value after reset)          |
|           |     |    | Attribute memory hold time                                     |
|           |     |    | For NAND Flash read/write accesses to the attribute memory     |
|           |     |    | space, these bits define the hold time of address signal (data |
|           |     |    | signal for write access) after command is sent (NWE and NOE    |
| Bit 23:16 | HLD | rw | become high) in HCLK clock cycle number.                       |
|           |     |    | 0000000: Reserved                                              |
|           |     |    | 0000001: 1 HCLK cycle                                          |
|           |     |    |                                                                |
|           |     |    | 11111111: 255 HCLK cycles (Default value after reset)          |
|           |     |    | Attribute memory x wait time                                   |
|           |     |    | For NAND Flash read/write accesses to the attribute memory     |
|           |     |    | space, these bits define the minimum time of command hold      |
|           |     |    | (NWE and NOE are low) in HCLK clock cycle number (+ 1). The    |
|           |     |    | duration for command assertion is extended if the wait signal  |
|           |     |    | (NWAIT) is active (low) at the end of the programmed value of  |
| Bit 15:8  | OP  | rw | HCLK.                                                          |
|           |     |    | 00000000: Reserved                                             |
|           |     |    | 00000001: 1 HCLK cycle (+ wait cycle introduced by             |
|           |     |    | deasserting NWAIT)                                             |
|           |     |    |                                                                |
|           |     |    | 11111111: 255 HCLK cycles (+ wait cycle introduced by          |
|           |     |    | deasserting NWAIT from Card)                                   |
|           |     |    | Attribute memory x setup time                                  |
| Bit 7:0   | CTD | rw | For NAND Flash read/write accesses to the attribute memory     |
|           | STP |    | space, these bits define address signal setup time before      |
|           |     |    | command assertion (NWE and NOE go low) in HCLK clock cycle     |
|           |     |    | zhou Vango Technologies Inc. 736 / 782                         |



Hangzhou Vango Technologies, Inc.

|  |  | number (+ 1).                                         |
|--|--|-------------------------------------------------------|
|  |  | 00000000: 1 HCLK cycle                                |
|  |  |                                                       |
|  |  | 11111111: 256 HCLK cycles (Default value after reset) |

### 18.4.2.5 ECC Result Register 2 (XMC\_BK2ECC)

Address offset:  $0xA0000000 + 0x54 + 0x20^* (x - 1), x = 2$ 

Reset value: 0x0000000

The register contains the current error correction code value computed by the ECC computation modules of XMC controller, one ECC module per NAND Flash memory bank. When CPU reads/writes the data from the NAND Flash at the correct address (See <u>Section 18.3.3.6</u>), ECC computation module automatically processes the data written or read. According to the ECCPGSIZE field in the XMC\_BK2CTRL registers, after the last byte read, CPU must read the computed ECC value from the MC\_BK2ECC register, and then compare the value with those data recorded in the NAND Flash spare area, to determine whether it is valid and can be used for correction if applicable. After being read, the XMC\_BK2ECCR register must be cleared by configuring the ECCEN bit as '0'. The ECCEN bit is set to '1' again when computing a new data block.

| Bit      | Name | Туре | Description                                                                 |
|----------|------|------|-----------------------------------------------------------------------------|
| Bit 31:0 | ECC  | r    | ECC result<br>The computed result generated by the ECC circuit. Table 18-35 |
|          |      |      | shows the content of these bits.                                            |

Table 18-35 ECC Result Relevant Bit

ango

| 011 | 2048                                   | ECC[27:0] |
|-----|----------------------------------------|-----------|
| 100 | 4096                                   | ECC[29:0] |
| 101 | 8192<br>angzhou Vango Technologies, In | ECC[31:0] |



# **19 Universal Serial Bus Full-speed Device Interface (USBDEV)**

### **19.1 Introduction**

The USB peripheral implements an interface between a full-speed USB 2.0 bus and the APB1 bus. The USB peripheral supports suspend/resume operation, which allows to stop the device clocks for low-power consumption.

## 19.2 USB Main Features

- Compliance with USB2.0 full-speed device specification
- Configurable number of USB endpoints from 1 to 8
- CRC (Cyclic redundancy check) generation/checking; non-return-to-zero inverted (NRZI) encoding/decoding and bit-stuffing
- Supports isochronous transfers
- Supports double-buffered bulk/isochronous endpoint
- Supports USB suspend/resume operations
- Frame locked clock pulse generation

Note:USB and CAN share a dedicated SRAM memory for data transmission and reception, so they cannot be used concurrently (The shared SRAM is accessed through CAN and USB exclusively). USB and CAN can be used in the same application but not at the same time. When USB uses the shared SRAM memory, two address mapping spaces are available on APB1, and they can be selected with the USB768B bit in the RCC\_MISC register. When USB768B is 0, the size of SRAM is 512 bytes, and the address range is 0x40006000 ~ 0x400063FF; when USB768B is 1, the size of SRAM is 768 bytes, and the address range is 0x40007800 ~ 0x40007FFF. When CAN uses this shared SRAM, since CAN accesses it with the internal control bus, the USB768B (control) bit is only valid for USB and has no effect on CAN accesses.

Figure 19-1 shows the block diagram of the USB peripheral.

Figure 19-1 USB Peripheral Block Diagram





### **19.3 Function Overview**

The USB peripheral provides an USB standard compliant communication between the host PC and the function implemented by the microcontroller. Data transfer between the host PC and the microcontroller is completed through a shared dedicated data buffer memory accessed directly by the USB peripheral. The size of this dedicated buffer memory is determined by the number of endpoints used and the maximum packet size of each endpoint; each endpoint can use the maximum of 512-byte/768-byte buffer, which can be used for up to 16 mono-directional or 8 bidirectional endpoints. The USB peripheral interfaces with the PC host, detecting token packets, handling data transmission/reception, and processing handshake packets in compliance with the USB standard. Transaction formatting is performed by the hardware, including CRC generation and checking.

Each endpoint is with a buffer description block, indicating the buffer address used by the endpoint, its size, and the number of bytes should be transmitted. When a token for a valid function/endpoint pair is



recognized by the USB peripheral, the related data transfer (if required, and if the endpoint is configured) will take place. Data transfer between the interface and the dedicated buffer is performed by the USB peripheral through an internal 16-bit register. After all data transfer is completed, if needed, the proper handshake packet over the USB is generated or expected according to the direction of the transfer.

At the end of the transaction, an endpoint-specific interrupt is generated by the USB peripheral; by reading status registers and/or using different interrupt response routines, the microcontroller can determine:

- Which endpoint to be served
- The type of transaction in progress if errors occur, such as bit stuffing, format, CRC, protocol, missing ACK, over/underrun, etc.

The USB peripheral provides special double buffer support for isochronous transfers and high throughput bulk transfers, which allows the USB peripheral to always have an available buffer while the microcontroller uses the other one.

The USB peripheral can be placed in low-power mode (SUSPEND mode) by writing in the control register, whenever it is not used. In this case, static power dissipation is avoided, and the USB clock can be slowed down or stopped. The detection of activity at the USB inputs can wake up the device in low-power mode. A special interrupt source can also be connected directly to a wakeup line, enabling the system to immediately restart the normal clock generation and to support direct clock start/stop.

#### **19.3.1 USB Blocks Function Description**

The USB peripheral implements all the features related to USB interfacing, and it consists of the following blocks:

• Serial interface engine (SIE): The functions of this block include: Synchronization pattern recognition, bit-stuffing, CRC generation and checking, PID verification/generation, and handshake evaluation. It must interface with the USB transceivers and use the virtual buffers provided by the packet buffer interface for local data storage. This unit also generates signals according to USB peripheral events and to endpoint related events like end of transmission or correct reception of a packet, such as Start of Frame (SOF), USB\_Reset, data errors, etc. These signals can generate interrupts.

• Timer: This block generates a start-of-frame locked clock pulse and detects a global suspend (from the host) when no transfer is received for 3 ms.



• Packet buffer interface: This block manages the temporary local memory for transmission and reception. It can assign proper buffers according to requests coming from SIE, and locate them in the memory addresses pointed by the endpoint registers. It increments the address after each byte transfer until the end of packet, keeping track of the number of exchanged bytes and preventing the buffer from overrunning.

• Endpoint-related registers: Each endpoint has an associated register indicating the endpoint type and its current status. For mono-directional/single-buffered endpoints, a single register can be used to implement two distinct endpoints. There are 8 registers used for up to 16 mono-directional/single-buffered endpoints, or up to 7 double-buffered endpoints and their combinations. For example, 4 double-buffered endpoints and 8 single-buffered/mono-directional endpoints can be implemented simultaneously.

• Control registers: These are the registers containing information about the status of the whole USB peripheral and triggering USB events, such as resume and power-down, etc.

• Interrupt registers: These registers contain the interrupt masks and the records of interrupt events. Configuring and accessing these registers can obtain information like interrupt sources and interrupt status, also clearing status flags of pending interrupts.

Note: Endpoint 0 is always used as the control endpoint in single-buffer mode.

The USB peripheral is connected to the APB1 bus through an APB1 interface, which contains the following blocks:

• Packet memory: This is the local memory that contains the packet buffers. It is controlled by the packet buffer interface, which creates the data structure and can be accessed directly by the application software. The size of the packet memory is 512/768 bytes, consisting of 256/384 16-bit words.

• Arbiter: This block handles memory requests coming from the APB1 bus and from the USB interface. It resolves bus conflicts by giving higher priority to APB1 accesses, and always reserves half of the memory bandwidth to complete all the USB transfers. It adopts time-duplex scheme to implement a virtual dual-port SRAM, which allows memory accesses while an USB transaction is in progress. This scheme also allows multi-word APB1 transfers with any lengths.

• Register mapper: This block maps various byte-wide and bit-wide registers of the USB peripheral in a structured 16-bit wide word set ,which can be addressed by APB1.

• APB1 wrapper: This block provides an interface to APB1 for the memory and register. It also maps the whole USB peripheral in the APB1 address space.



• Interrupt mapper: This block is used to map the USB events that can possibly generate interrupts to three different NVIC lines:

- USB low-priority interrupt (Channel 20 or 74)<sup>1</sup>: Triggered by all USB events (correct transfer, USB reset, etc.). The firmware has to check the interrupt source first before serving the interrupt.

- USB high-priority interrupt (Channel 19 or 73)<sup>1</sup>: Triggered only by a correct transfer event of isochronous and double-buffer bulk transfer, in order to reach the highest transfer rate.

- USB wakeup interrupt (Channel 42): Triggered by wakeup events from the USB suspend mode.

*Note:* USBDEV module interrupt supports remapping. When the USB\_INT\_CTRL bit of RCC\_INTCTRL is set, Channel 19 can be remappable to channel 73, and channel 20 can be remappable to channel 74.

### **19.3.2 Generic USB Device Programming**

This section describes the main tasks done by the application to implement the USB function. In addition to general actions taken in USB events, this section also emphasizes the special cases of double-buffered endpoints and isochronous transfers. These relevant actions are always initialized by the USB peripheral and triggered by one of the USB events described below.

#### 19.3.2.1 System Reset and Power-on Reset

Upon system reset or power-on reset, the application should first provide all required clock signals to the USB peripheral and then de-assert its reset signal, which allows the USB peripheral to access the registers. The complete initialization sequence is described as follows:

First, the application should activate the macrocell register clock and de-assert macrocell-specific reset signal by configuring the relevant control bits of the device clock management logic.

After that, the analog part associated with the USB transceiver must be switched on by configuring the PDWN bit in the CTRL register; this step requires special attention. This bit can switch on the internal voltage references that supply the port transceiver. This circuit has a defined startup time (tSTARTUP specified in the datasheet) during which the behavior of the USB transceiver is undefined. Therefore, it is necessary to wait for a period of time before clearing the reset signal on the USB part (by clearing the FRST bit in the CTRL register). Clearing the INTSTS register will remove any spurious pending interrupt before any other macrocell operation is enabled.

configuring the corresponding control bits of the device clock management logic.

During system reset, the microcontroller must initialize all required registers and the packet buffer description table, to make the USB peripheral able to properly generate interrupts and complete data transfers. All registers not specific to any endpoint must be initialized according to the needs of application (e.g. selection of interrupt enable or address of packet buffers, etc.). Then, the process is the same as the one for the USB reset case (Please refer to the next section).

#### **USB reset (RSTF interrupt)**

When USB reset occurs, the USB peripheral will be at system reset state as described in the previous sections: communication is disabled in all endpoint registers (the USB peripheral will not respond to any packet). After USB reset, the USB function is enabled, at the same time enabling the default control endpoint (endpoint 0) of which the address is 0. This is accomplished by setting the EN bit in the USB\_DEVADR register, the EPT0 register, and its related packet buffers accordingly. During USB enumeration process, the host assigns a unique address to this device, which must be written in the ADR [6:0] bits of the USB\_DEVADR register, and configures any other necessary endpoints.

When a RESET interrupt is received, the application must enable the default endpoint 0 within 10 ms after the interrupt is generated.

#### Structure and usage of packet buffers

Each bidirectional endpoint may receive or transmit data from/to the host. The received data is stored in a dedicated memory buffer reserved for that endpoint, while the other memory buffer contains the data to be transmitted by the endpoint. Accesses to this memory are performed by the packet buffer interface block, which delivers a memory access request and waits for its acknowledgement. To avoid the access conflict between the microcontroller and the USB peripheral, the packet buffer interface block adopts an arbitration logic, using half APB1 cycle for microcontroller access and the other half for the USB peripheral access. In this way, both the microcontroller and USB can operate as if the packet memory is a dual-port SRAM; no conflict will occur even when the microcontroller is performing accesses continuously.

The USB peripheral logic uses a dedicated clock. The frequency of this dedicated clock is fixed according to the requirements of the USB standard at 48 MHz. APB1 clock frequency can be higher or lower than this frequency.

Note: To fulfill USB data rate and packet memory interface requirements, the APB1 clock frequency



Hangzhou Vango Technologies, Inc.

must be greater than 8 MHz to avoid data overrun/underrun problems.

Each endpoint is associated with two packet buffers (Usually, one for transmission and the other for reception). Buffers can be placed anywhere inside the packet memory because their locations and sizes are specified in a buffer description table, which is also located in the packet memory at the address indicated by the register.

Each table entry is associated to an endpoint register, which is composed of 4 16-bit words so that the start address of the table must always be aligned to an 8-byte boundary (the least significant 3 bits of the register are always '000'). If an endpoint is unidirectional, neither isochronous nor double-buffered bulk, only one packet buffer is required (the one related to the supported transfer direction).

Other table locations related to unsupported transfer directions or unused endpoints are available for other purposes. Isochronous and double-buffered bulk endpoints have special handling on packet buffers. The relationship between buffer description table entries and packet buffer areas is detailed in Figure 19-2.

Figure 19-2 Packet Buffer Areas and Associated Buffer Description Table Locations





Each packet buffer is used from the bottom either during reception or transmission. The USB peripheral will never change the contents of memory locations adjacent to the allocated memory buffers; if a packet bigger than the allocated buffer length is received, the buffer only receives data with its own size and discards the others; that is, a buffer overrun error will occur.

#### **Packet Buffer Area Configuration**

Two mapping intervals are available for packet buffer area, and are selected by the USB768B bit in the RCC\_MISC register. When USB768B is 0, SRAM size is fixed to 512 bytes, and the address range is fixed to 0x4000 6000 ~ 0x4000 63FF; when USB768B is 1, SRAM size is fixed to1024 ~ 1280 bytes, and the address range is fixed to 0x4000 7800~0x4000 81FF. Buffer size is decided by whether CAN1 are enabled; when both CAN1 are disabled, USB packet buffer can be set to the maximum of 1280 bytes; When CAN1 is disabled, the USB packet buffer can be set to a maximum of 1280 bytes. When CAN1 is enabled, the USB



packet buffer can be set to a maximum of 1024 bytes.

| Condition             | USB768B     | 0                | 1            |              |
|-----------------------|-------------|------------------|--------------|--------------|
| Condition             | CAN1 Status | Enabled/Disabled | Disabled     | Enabled      |
| Packet Buffer Size    |             | 512BYTE          | 1280BYTE     | 1024BYTE     |
| Packet Buffer Address |             | 0x4000 6000~     | 0x4000 7800~ | 0x4000 7800~ |
| R                     | ange        | 0x4000 63FF      | 0x4000 81FF  | 0x4000 7FFF  |

Table 19-1 Packet Buffer Area Configuration

#### **Endpoint initialization**

The first step to initialize an endpoint is to write appropriate values to the ADRn\_TX/ ADRn\_RX registers, so that the USB peripheral can find the data to be transmitted or the buffer already available to receive data. The EPT\_TYPE bits in the USB\_EPTx register must be set to determine the endpoint type, and the EPT\_SUBTYPE bit to determine their special required features. On the transmit side, the endpoint must be enabled through the STS\_TX bits in the USB\_EPTx register, and CNTn\_TX must be configured to define the transmission length. For reception, the STS\_RX bits must be set to enable the endpoint, and the BLKSIZE and the NUM\_BLK bits must be written with the allocated buffer size, to detect buffer overrun errors. For unidirectional, non-isochronous, and non-double-buffered bulk endpoints, only one register related to the supported direction should be configured. Once the endpoint is enabled, the USB\_EPTx register and locations of ADRn\_TX/ ADRn\_RX, CNTn\_TX/ CNTn\_RX can no longer be modified by the application software, as the hardware can change their values on the fly. When the data transfer is completed, a CTFRF interrupt will be generated, and the above-mentioned registers can be accessed again to re-enable a new operation.

#### IN packets (for data transmission)

When receiving an IN token packet, if the received address matches the configured endpoint address, the USB peripheral will access the corresponding ADRn\_TX and CNTn\_TX registers based on the entry of buffer description table; then, the contents of these registers are stored in its internal 16-bit registers, ADDR and COUNT (not accessible by software). At this time, the USB peripheral starts sending a DATA0 or DATA1 packet according to the DTOG\_TX bit and accesses the buffer. After IN packet is completed, the first byte read from buffer memory is loaded into the output shift register, starting to be transmitted. After the last data byte is transmitted, the computed CRC is sent. If the addressed endpoint is not valid, a NAK or STALL handshake packet is sent instead of the data packet, according to the STS\_TX bits in the



The ADDR internal register is used as a pointer to the current location of buffer memory, while the COUNT register is used to count the number of remaining bytes to be transmitted. Each word read from the packet buffer memory is transmitted over the USB bus, starting from the least significant byte. Transmission buffer memory is read from the address pointed by ADRn TX, and the length is CNTn TX/2 words. If a transmitted packet is composed of an odd number of bytes, only the lower 8 bits of the last word accessed will be used.

On receiving the ACK by the host, the USB EPTx register is updated in the following way: The DTOG TX bit is toggled, the endpoint is made invalid by setting  $STS_TX = 10$ , and the  $CTFR_TX$  bit is set. The application must first identify the endpoint, which generates interrupts, by examining the EPT\_ID and DIR bits in the USB\_INTSTS register. Service of the CTFR\_TX event first clears the interrupt bit, then prepares another buffer to be sent, updates CNTn TX with the number of byte to be transmitted during the next transfer, and finally sets STS\_TX to '11' (endpoint valid) to re-enable transmissions. When the STS\_TX bits are '10' (endpoint NAK), any IN request addressed to that endpoint is NAKed, and the USB host will re-send the IN request until the endpoint confirms the request to be valid. It is required to execute the sequence of operations in the above mentioned order to avoid losing the next IN transaction following the previous CTFR interrupt request.

#### OUT and SETUP packets (data reception)

ango

These two tokens are handled by the USB peripheral more or less in the same way; the differences in the handling of SETUP packets are detailed in the following section about control transfers. When receiving an OUT/SETUP packet, if the address matches a valid endpoint, the USB peripheral accesses the buffer descriptor table, finds the ADRn\_RX and CNTn\_RX registers related to the addressed endpoint, and stores the content of the ADRn RX register in its internal register, ADDR. At the same time, COUNT is reset; the values of BLKSIZE and NUM BLK, read from CNTn RX, are used to initialize an internal 16 bit register, BUF\_COUNT, which is used to check the buffer overrun condition (All these internal registers are not accessible by software). Data bytes subsequently received by the USB peripheral are packed in words (The first byte received is stored as the least significant byte) and then transferred to the packet buffer pointed by ADDR. At the same time, the value of BUF\_COUNT is decremented automatically, while COUNT is incremented at each byte transfer. When the end signal of data packet is detected, the correctness of the received CRC is tested. If no errors occur during the reception, an ACK handshake packet is sent back to the host. In case of wrong CRC or other kinds of errors (bit-stuff violations, frame errors, etc.), data bytes are still copied into the packet memory buffer, at least until the error detection point, but the ACK packet is not sent, and the ERRF bit in USB\_INTSTS register is set. However, there is 748 / 782 Hangzhou Vango Technologies, Inc.

usually no software action required in this case; the USB peripheral recovers from reception errors automatically and remains ready for the next transaction to come. If the addressed endpoint is not ready, a NAK or STALL handshake packet is sent, according to the STS\_RX bits in the USB\_EPTn register; no data is written in the reception memory buffers.

The location of reception memory buffer starts from the address contained in ADRn\_RX, and the length is determined by the data packet length (i.e. valid data length + 2), including CRC, but cannot exceed the buffer length defined by BLKSIZE and NUM\_BLK. If the length of the data packet payload is greater than the allocated buffer, data out of the range will not be written into the buffer, and the USB peripheral detects a buffer overrun condition. In this case, a STALL handshake is sent to notify this failure to the host, and no interrupt is generated.

When the transaction is completed correctly, the USB peripheral sends the ACK handshake packet, and the value of the internal COUNT register is copied into the corresponding CNTn\_RX register, leaving the BLKSIZE and NUM\_BLK fields unaffected and not required to be re-written. The USB\_EPTn register is updated in the following way: The DTOG\_RX bit is toggled, the endpoint is made invalid by setting STS\_RX = 10 (NAK), and the CTFR\_RX bit is set (If CTFRF interrupt is enabled, an interrupt will be triggered). If errors or buffer overrun condition occur during the transaction, none of the previously listed actions take place. When a CTFR interrupt occurs, the application software must first identify its endpoint by examining the EPT\_ID and DIR bits in the USB\_INTSTS register. The CTFR\_RX interrupt event is serviced by first determining the transaction type (based on the SETUP bit in the USB\_EPTn register); the application must clear the interrupt flag bit and obtain the number of received bytes by reading the CNTn\_RX register pointed by the buffer description table entry. After the received data is processed, the application should set the STS\_RX bits to '11' in USB\_EPT, enabling further transactions.

When the STS\_RX bits are '10' (NAK), any OUT request addressed to that endpoint is NAKed; the USB host will retry the transaction until it succeeds. It is necessary to execute the sequence of operations in the above mentioned order to avoid losing the second OUT transaction following the previous CTFR interrupt.

#### **Control transfer**

Control transfer consists of 3 phases: First, a SETUP transaction, followed by zero or more data stages, and finally a status stage, consisting of a data packet in the opposite direction. SETUP transactions are handled by control endpoints only and are very similar to the OUT process (data reception). To enable SETUP transfer, the DTOG\_TX and DTOG\_RX bits are initialized to `1' and `0', respectively; in addition,



STS\_TX and STS\_RX are set to '10' (NAK) to allow software to decide if subsequent transactions is IN or OUT depending on the SETUP contents. A control endpoint must check the SETUP bit in the USB\_EPTn register at each CTFR\_RX interrupt event to distinguish normal OUT transactions from the SETUP transactions. A USB device can determine the number and direction of transfer at data stage according to the corresponding data in SETUP transaction, and can send STALL transaction in the case of errors to reject data transfer. Therefore, at all data stages, the unused direction should be set to STALL; its opposite direction is still set as NAK during the last data transaction at data stage, so that if the host reverses the transfer direction too soon (entering status phase), it remains the state of waiting for control transfer completion. After the control operation is completed successfully, the software will change NAK to VALID; otherwise, it will be changed to STALL if errors occur. At the same time, if the status stage will be an OUT, the STATUS\_OUT bit (EPT\_SUBTYPE in the USB\_EPTn register) should be set, so that an error is generated if a status transaction is performed with nonzero data. When the status transaction is finished, the application clears the STATUS\_OUT bit and sets STS\_RX to VALID, indicating "ready to accept a new command", and STS\_TX to NAK, indicating that no data transfer request is accepted before the next SETUP transaction is completed.

The USB specification states that a SETUP packet cannot be answered with a handshake different from ACK; if SETUP packet transfer fails, a new one will be started. Therefore, it is not allowed to answer a SETUP token received from the host with a NAK or STALL packet.

When the STS\_RX bits are set to '01' (STALL) or '10' (NAK), and a SETUP token is received, the USB peripheral accepts the data, performing the required data transfers and sending back an ACK handshake. If that endpoint has a previously issued CTFR\_RX request not yet acknowledged by the application (i.e. the CTFR\_RX bit is still set), the USB discards the SETUP transaction and does not answer with any handshake packet, which simulating a reception error and forcing the host to send the SETUP token again. This is done to avoid losing the notification of a SETUP transaction addressed to the same endpoint following the CTFR\_RX interrupt.

#### **19.3.2.2** Double-buffered Endpoints

The USB standard not only defines the different endpoint types for different traffic models, but also describes the typical requirements of these data transfer operations. Among these operations, the bulk endpoint type is the most suited model for large portions of data transfer between the host PC and the USB peripheral; this is because the host can fill all the available bandwidth in the frame, maximizing the actual transfer rate. However, if the USB function is still busy with the previous transaction when the next



one arrives, it will answer with a NAK handshake, and the host PC will issue the same transaction again until the USB function is ready to handle it; this reduces the actual transfer rate due to the bandwidth occupied by re-transmissions. For this reason, a dedicated feature called "double-buffering" with bulk endpoints is introduced to increase transfer rate.

When "double-buffering" is activated, unidirectional data transfer will use both the transmission and reception data buffer of the endpoint. The data toggle bit is used to select which buffer is to be used by the USB peripheral to perform the required data transfers. While the USB peripheral is accessing one of the buffer, the application can perform operations on the other one. For example, during an OUT transaction directed to a double-buffered bulk endpoint, the USB peripheral will store data coming from the PC host into a buffer, and the other one is available for the application usage (The same would happen in an IN transaction). Since the swapped buffer management requires all four buffer description table locations to indicate the address pointers and the buffer length on each direction, the USB\_EPTn registers used to implement double-buffered bulk endpoints are forced to be unidirectional. Therefore, only the STS\_RX bit (double-buffered bulk endpoint for reception) or the STS\_TX bit (double-buffered bulk endpoint for reception) or the STS\_TX bit (double-buffered bulk endpoint for reception) registers are needed.

To exploit the double-buffering feature and reach the highest possible transfer rate, its endpoint flow control structure is a little different from other endpoints. It sets endpoint to NAK only when a buffer conflict occurs, instead of each time at the end of a successful transaction.

The DTOG bit is used to indicate the memory buffer currently being used. The receive direction of the double-buffer bulk endpoint is indicated by DTOG\_RX (the bit 14 of USB\_EPTn register), while the transmission direction is indicated by DTOG\_TX (the bit 6 of USB\_EPTn register). At the same time, the USB peripheral should know which packet buffer is currently in use by the application, to avoid any conflict. Since in the USB\_EPTn register, there are two DTOG bits, and the USB peripheral only uses one to indicate the buffer used by hardware, so the application can use the other bit to show which buffer is currently being used; this new flag is called the SW\_BUF bit. Table 19-2 lists the correspondence between the DTOG and SW\_BUF bits in the USB\_EPTn register when transmission and reception are implemented with double-buffered bulk endpoints.

| Table 19-2 Double-buffering | Bulk Endpoint - | - Buffer Flag | Definition |
|-----------------------------|-----------------|---------------|------------|
|-----------------------------|-----------------|---------------|------------|

| Aango           | Hangzhou Vango Technologies, Inc. 751 / 782 |                                     |  |
|-----------------|---------------------------------------------|-------------------------------------|--|
| DTOG            | DTOG_TX (The bit 6 of the USB_EPTn          | DTOG_RX (The bit 14 of the USB_EPTn |  |
| Buffer Flag Bit | As Transmission Endpoint                    | As Reception Endpoint               |  |

|        | register)                           | register)                          |  |
|--------|-------------------------------------|------------------------------------|--|
| SW_BUF | The bit 14 of the USB_EPTn register | The bit 6 of the USB_EPTn register |  |

The memory buffer currently being used by the USB peripheral is defined by the DTOG buffer flag, while the buffer currently in use by application software is identified by the SW\_BUF buffer flag. The indication of these two bits is the same and listed in Table 19-3.

| Endpoint  |      | SW_BUF | Packet Buffer Used by the | Packet Buffer Used by the |
|-----------|------|--------|---------------------------|---------------------------|
| Туре      | DTOG |        | USB Peripheral            | Application Software      |
|           | 0    | 1      | ADRn_TX_0/CNTn_TX_0       | ADRn_TX_1/CNTn_TX_1       |
| TN        | 1    | 0      | ADRn_TX_1/CNTn_TX_1       | ADRn_TX_0/CNTn_TX_0       |
| IN 0<br>1 | 0    | 0      | None(Note)                | ADRn_TX_0/CNTn_TX_0       |
|           | 1    | 1      | None(Note)                | ADRn_TX_0/CNTn_TX_0       |
|           | 0    | 1      | ADRn_RX_0/CNTn_RX_0       | ADRn_RX_1/CNTn_RX_1       |
| OUT       | 1    | 0      | ADRn_RX_1/CNTn_RX_1       | ADRn_RX_0/CNTn_RX_0       |
|           | 0    | 0      | <sub>None</sub> (Note)    | ADRn_RX_0/CNTn_RX_0       |
|           | 1    | 1      | None(Note)                | ADRn_RX_1/CNTn_RX_1       |

Table 19-3 Double-buffered Bulk Endpoint Flags

Note: Endpoint is at NAK state.

Double-buffering feature for a bulk endpoint is activated by:

- Setting the EPT\_TYPE bit field as '00' in the USB\_EPTn register, to define the endpoint as a bulk
- Setting the EPT\_SUBTYPE bit as `1' in the SB\_EPTn register, to define the endpoint as double-buffered

The application software initializes the DTOG and SW\_BUF bits according to the buffer used when transfer starts; this should take the special toggle-only property of the two bits into consideration. After setting DBL\_BUF, each time when a transfer is completed, the USB peripheral controls the operation according to the flow of double-buffered bulk endpoints, which is used for all other transactions addressed to this endpoint until DBL\_BUF becomes invalid. At the end of each transaction, the CTFR\_RX or CTFR\_TX bit is set, depending on the enabled direction. At the same time, the DTOG bit is set by hardware, implementing buffer swap mechanism in a complete software-independent way. After the DBL\_BUF bit is set, after each transfer completion, the value of STAT bit at double-buffered bulk endpoint is not affected like other common transactions, and it remains '11' (Valid). However, as the token packet of a new transaction is received, the actual endpoint status will be masked as '10' (NAK) when a buffer conflict between the USB



peripheral and the application software is detected (i.e. DTOG and SW\_BUF have the same value). The application software responds to the CTFR event by first clearing the interrupt flag and then handling the completed transaction. After the application accesses the buffer, the software toggles the SW\_BUF bit, to notify the USB peripheral about the availability of that buffer. In this way, the number of NAKed transactions is determined only by the application elaboration time of a transaction data: If the elaboration time is shorter than the time required to complete a transaction on the USB bus, no retransmissions will take place, and the actual transfer rate will be limited only by the USB host. The application software can always override the special flow control implemented for double-buffered bulk endpoints, writing an explicit status different from '11' (Valid) into the STS bit pair of the related USB\_EPTn register. In this case, the USB peripheral will always use the programmed endpoint status, regardless of the actual buffer usage condition.

#### 19.3.2.3 Isochronous Transfers

The USB standard supports full speed peripherals requiring a fixed and accurate data transfer frequency: Isochronous transfer. Isochronous transfer is commonly used for audio samples, compressed video streams, and in general any sort of data having strict requirements for the delivered frequency. When an endpoint is defined to be "isochronous" at the enumeration phase, the USB host allocates each frame with fixed bandwidth and ensures that each frame transfers exactly one IN or OUT packet (depending on endpoint direction). To fulfill the bandwidth requirements, there is no retransmission of failed transactions for isochronous traffic; this leads to the fact that an isochronous transaction does not have a handshake phase, and no ACK packet is sent after the data packet transactions. For the same reason, isochronous transfers do not support data toggle sequencing and always uses DATAO PID (packet ID) to start any data packet.

The isochronous behavior for an endpoint is selected by setting the EPT\_TYPE bits at '10' in the USB\_EPTn register. Since there is no handshake phase, the only legal values for the STS\_RX/STS\_TX bit pairs are '00' (Disabled) and '11' (Valid) according to the USB standard. Isochronous endpoints implement double-buffering to ease the software application development, using both transmission and reception buffer areas to ensure that application can access one buffer while the USB peripheral fills the other.

The memory buffer used by the USB peripheral is defined by the DTOG bit related to the endpoint direction (DTOG\_RX for "reception" isochronous endpoints, DTOG\_TX for "transmission" isochronous endpoints, both in the related register) according to Table 19-4.

Table 19-4 Isochronous Memory Buffers Flags



Hangzhou Vango Technologies, Inc.

| Endpoint<br>Type | DTOG | Packet Buffer Used by USB<br>Peripheral | Packet Buffer Used by Application<br>Software |
|------------------|------|-----------------------------------------|-----------------------------------------------|
| TN               | 0    | ADRn_TX_0/CNTn_TX_0                     | ADRn_TX_1/CNTn_TX_1                           |
| IN -             | 1    | ADRn_TX_1/CNTn_TX_1                     | ADRn_TX_0/CNTn_TX_0                           |
|                  | 0    | ADRn_RX_0/CNTn_RX_0                     | ADRn_RX_1/CNTn_RX_1                           |
| OUT              | 1    | ADRn_RX_1/CNTn_RX_1                     | ADRn_RX_0/CNTn_RX_0                           |

As it happens with double-buffered bulk endpoints, the USB\_EPTn registers only implement unidirectional transfers of isochronous endpoints. If it is required to have isochronous endpoints enabled for two directions, then two USB\_EPTn registers must be used. The application software is responsible for the DTOG bit initialization according to the first buffer used; this has to be done considering the special toggle-only property that these two bits have. At the end of each transaction, the CTFR\_RX or CTFR\_TX bit of the addressed endpoint USB\_EPTn register is set. At the same time, the related DTOG bit is hardware toggled, making buffer swapping completely software independent. The STS\_RX or STS\_TX bits are not affected after transaction completion; due to the lack of handshake phase, no flow control is needed, and the endpoint always remains '11' (Valid). During isochronous transfers, CRC errors or buffer-overrun conditions are still considered as correct transactions and can trigger a CTFR\_RX interrupt event. However, CRC errors will set the ERRF bit in the USB\_INTSTS register to notify the software of the possible data corruption.

#### 19.3.2.4 Suspend/Resume Events

The USB standard defines a special peripheral state, called SUSPEND, in which the average current drawn from the USB bus is under 500 uA. This requirement is very important for bus-powered devices, while self-powered devices are not required to comply with this strict power consumption constraint. The USB host enters the suspend mode if it does not send any traffic on the USB bus for more than 3 ms; normally, a SOF packet is sent every ms by the USB peripheral, so the lack of 3 consecutive SOF packets is identified as a suspend request from the host, and USB will set the SUSPF bit to '1' in the USB\_INTSTS register, generating an interrupt. Once the device is suspended, its normal operation can be restored by a "RESUME" sequence, which can be started from the host or directly from the peripheral itself, but it is always terminated by the host. The suspended USB peripheral must be able to detect a RESET sequence and react to this event as a normal USB reset operation.

The actual procedure used to suspend the USB peripheral is device-dependent, since different actions



Hangzhou Vango Technologies, Inc.

may be required to reduce the total consumption for different devices. A brief description of a typical suspend procedure is provided below, focusing on how the application software responds to the SUSPF notification of the USB peripheral:

1. Set the FSUSP bit in the USB\_ CTRL register to '1', activating the suspend mode within the USB peripheral. As soon as the suspend mode is activated, the check on SOF reception is disabled to avoid any further SUSPF interrupts issued while USB is suspended.

2. Remove or reduce any static power consumption in other blocks aside from the USB peripheral.

3. Set the LPWR bit in the USB\_CTRL register to '1' to remove static power consumption in the analog USB transceivers but keep them able to detect resume signal.

4. Optionally turn off external oscillator and PLL of the device to stop any activity inside the device. When an USB event occurs while the device is in suspend mode, the "RESUME" procedure must be invoked to restore nominal clocks and regain normal USB behavior. Particular attention must be given to ensure that this process does not take more than 10 ms if the wakening event is an USB reset sequence (Please refer to "Universal Serial Bus Specification" for more details). When the USB peripheral is suspended, the start of a resume or reset sequence clears the LPWR bit in the USB\_CTRL register. Even if this event can trigger a WKUPF interrupt immediately, the interrupt response routine must be carefully evaluated because of the long latency required by system clock restart; to reduce the latency before re-activating the nominal clock, it is suggested that users put the resume procedure right after the end of the suspend code, so its code is immediately executed as soon as the system clock restarts.

The following is the resume procedure: Enable external oscillator and PLL of the device (optional)

1. Clear the FSUSP bit in the USB\_USB\_CTRL register.

2. The DPSTS and DMSTS bits in the USB\_ FRNUM register can be used to identify the resume triggering event, as shown in Table 19-5, which also lists the intended software action in all the cases. If required, the end of resume or reset sequence can be detected by monitoring the time when the two bits reach '10' (which indicates the idle bus state); moreover, at the end of a reset sequence, the RSTF bit in USB\_ INTSTS register is set to '1', issuing an interrupt if enabled. This interrupt should be handled as a usual reset.

Table 19-5 Resume Event Detection

[DPSTS, DMSTS] Status

Wakeup Event

Required Software Resume Action



| 00 | Reset                        | None                     |
|----|------------------------------|--------------------------|
| 10 | None (Noise on the bus)      | Go back to suspend state |
| 01 | Resume                       | None                     |
| 11 | Undefined (Noise on the bus) | Go back to suspend state |

A device may require to exit from the suspend mode as an answer to particular events not directly related to the USB protocol (e.g. a mouse movement wakes up the whole system). In this case, the resume sequence can be started by setting the RESUME bit in the USB\_CTRL register to '1' and resetting it to 0 after an interval between 1 ms and 15 ms (this interval can be timed by ESOF interrupts, which occur every 1 ms period when the system clock is running at normal frequency). Once the RESUME bit is cleared, the resume sequence will be completed by the host PC, and its completion can be monitored by the DPSTS and DMSTS bits in the USB\_ FRNUM register.

*Note:* The RESUME bit must be configured only after the USB peripheral is put in suspend mode (setting the FSUSP bit in the USB\_ CTRL register to `1').

#### 19.3.2.5 Output of SOF

Every time the device receives SOF on the USB bus, it will generate the first frame flag SOFF. The current frame number can be read from the number register at the beginning of the USB frame. At this time, a SOF pulse signal with a width of 12 APB1 clocks will be generated. By enabling the SOFOUTEN bit of the USB SOF control register, this SOF pulse signal can be output to the chip pin.

### **19.4 USB Registers**

The USB peripheral registers include the following three groups:

- Common registers: Interrupt registers and control registers
- Endpoint registers: Endpoint configuration registers and status registers
- Buffer description table registers: Registers that define the addresses to store packet memory

The base addresses of buffer description table registers are specified by the USB\_BUFTBL register. All other registers are expressed with respect to the base address of the USB peripheral: 0x40005C00. Since APB1 addresses on a word (32-bit) basis, all register addresses are aligned to 32-bit word boundaries even though they are 16-bit wide. The same address alignment is used to access packet buffer memory locations, which are located starting from 0x40006000/ 0x40007800.



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

## **19.4.1 Common Registers**

These registers define the USB peripheral's operating mode, interrupt handling, device address, and the access to the current frame number.

### 19.4.1.1 USB Control Register (USB\_CTRL)

Address offset: 0x40

Reset value: 0x0003

| Bit    | Name                | Туре         | Description                                                          |
|--------|---------------------|--------------|----------------------------------------------------------------------|
|        |                     |              | Correct transfer (CTFRF) interrupt mask                              |
| Bit 15 | CTFR_IEN            | rw           | 0: Correct transfer (CTFRF) interrupt is disabled.                   |
| DICIS  | ••••• <u>-</u> •-•• |              | 1: Correct transfer (CTFRF) interrupt is enabled; an interrupt is    |
|        |                     |              | generated if the corresponding bit in the interrupt register is set. |
|        |                     |              | Packet memory area over/underrun interrupt mask                      |
|        |                     | <b>F</b> 14/ | 0: PMOVR interrupt is disabled.                                      |
| Bit 14 | PMOVR_IEN           | rw           | 1: PMOVR interrupt is enabled; an interrupt is generated if the      |
|        |                     |              | corresponding bit in the interrupt register is set.                  |
|        |                     |              | Error interrupt mask                                                 |
| Bit 13 | ERR_IEN             | rw           | 0: Error interrupt is disabled.                                      |
|        |                     |              | 1: Error interrupt is enabled; an interrupt is generated if the      |
|        |                     |              | corresponding bit in the interrupt register is set.                  |
|        |                     |              | Wakeup interrupt mask                                                |
| Bit 12 | WKUP_IEN            | rw           | 0: Wakeup interrupt is disabled.                                     |
|        |                     |              | 1: Wakeup interrupt is enabled; an interrupt is generated if the     |
|        |                     |              | corresponding bit in the interrupt register is set.                  |
|        |                     |              | Suspend mode interrupt mask                                          |
| Bit 11 | SUSP_IEN            | rw           | 0: Suspend mode (SUSPF) interrupt is disabled.                       |
|        |                     |              | 1: Suspend mode (SUSPF) interrupt is enabled; an interrupt is        |



|        |          |     | generated if the corresponding bit in the interrupt register is set. |
|--------|----------|-----|----------------------------------------------------------------------|
|        |          |     | USB reset interrupt mask                                             |
| Bit 10 | RST_IEN  | rw  | 0: USB RSTF interrupts is disabled.                                  |
| BIC 10 |          |     | 1: USB RSTF interrupts is enabled; an interrupt is generated if the  |
|        |          |     | corresponding bit in the interrupt register is set.                  |
|        |          |     | Start of frame interrupt mask                                        |
|        | SOF_IEN  | rw  | 0: SOFF interrupts is disabled.                                      |
| Bit 9  | SOI_ILN  | IVV | 1: SOFF interrupts is enabled; an interrupt is generated if the      |
|        |          |     | corresponding bit in the interrupt register is set.                  |
|        |          |     | Expected start of frame interrupt mask                               |
|        |          |     | 0: ESOF interrupts is disabled.                                      |
| Bit 8  | ESOF_IEN | rw  | 1: ESOF interrupts is enabled; an interrupt is generated if the      |
|        |          |     | corresponding bit in the interrupt register is set.                  |
|        |          |     | Resume request                                                       |
|        | DECLIME  |     | Setting this bit will send a resume signal to the host. According to |
| Bit 4  | RESUME   | rw  | the USB specification, if this bit remains active for 1 ms to 15 ms, |
|        |          |     | the host will perform the resume sequence to the USB peripheral.     |
|        | FSUSP    | rw  | Force suspend                                                        |
|        |          |     | When no traffic is received by the USB peripheral for 3 ms, the      |
|        |          |     | SUSPF interrupt is issued, and then the software must set this bit.  |
| Bit 3  |          |     | 0: No effect                                                         |
|        |          |     | 1: Enter suspend mode. Clocks and static power dissipation in the    |
|        |          |     | analog transceiver are left unaffected. If low-power consumption is  |
|        |          |     | required (bus-powered devices), the application software should set  |
|        |          |     | the FSUSP bit and then the LPWR bit.                                 |
|        |          |     | Low-power mode                                                       |
|        | LPWR     |     | This mode is used to lower the power consumption at USB suspend      |
| Bit 2  |          | rw  | state. In this mode, all static power dissipation is avoided, except |
|        |          |     | the one required to supply the external pull-up resistor. The system |
|        |          |     | clocks may stop or reduce their frequencies to meet the power        |
|        |          |     | consumption requirements. The USB activity (wakeup event) during     |



|       |      |    | the suspend mode will reset this bit (it can also be reset by              |
|-------|------|----|----------------------------------------------------------------------------|
|       |      |    | software).                                                                 |
|       |      |    | 0: No low-power mode                                                       |
|       |      |    | 1: Low-power mode                                                          |
|       |      |    | Power down                                                                 |
|       |      | rw | This bit is used to completely disable the USB peripheral. When this       |
| Bit 1 | PDWN |    | bit is set, the USB peripheral cannot be used.                             |
|       |      |    | 0: Exit power-down mode                                                    |
|       |      |    | 1: Enter power-down mode                                                   |
|       |      |    | Force USB Reset                                                            |
| Bit 0 | FRST | rw | 0: Clear the USB reset signal                                              |
|       |      |    | 1: Force a reset to the USB peripheral, similar to the reset signal on     |
|       |      |    | the USB bus. The USB peripheral is held at reset state until software      |
|       |      |    | clears this bit. A reset interrupt is generated if the USB reset interrupt |
|       |      |    | is enabled.                                                                |

#### **19.4.1.2 USB Interrupt Status Register (USB\_INTSTS)**

Address offset: 0x44

Reset value: 0x0400

This register contains the status of all the interrupt sources, allowing the application to determine the event that generates an interrupt request.

Each of the upper 8 bits in this register represents an interrupt source. These bits are set by the hardware when the corresponding event occurs; if the corresponding bit in the USB\_CTRL register is set, an interrupt request is generated. The interrupt routine should examine each bit, and must clear the corresponding status bits after performing all necessary operation; otherwise, the interrupt line will be kept high, causing the same interrupt to be triggered again. If several bits are set simultaneously, only a single interrupt will be generated. Interrupts can be handled in a different way by the application to reduce interrupt response latency. The CTFRF bit is set by the hardware as soon as an endpoint successfully completes a transaction, generating an interrupt request if the corresponding bit in USB\_CTRL is set. An endpoint dedicated interrupt flag is independent of the CTFR\_IEN bit in the USB\_CTRL register. Both the interrupt flag bits remain active until software clears the pending bit in the



corresponding USB\_EPTn register (the CTFRF bit is read-only). The USB peripheral has two interrupt request sources:

High priority USB IRQ: Used for interrupt requests of endpoints with higher priority (isochronous and double-buffered bulk endpoints), and the interrupt cannot be masked.

Low priority USB IRQ: Used for other interrupt events, such as unmaskable interrupts with lower priority or maskable interrupts identified by the upper 8 bits in the USB\_INTSTS register. For endpoint-related interrupts, the software can use the DIR register and the EP\_ID read-only bits to identify which endpoint makes the last interrupt request and to call the corresponding interrupt service routine.

When handling simultaneous pending interrupt events, users can check the order of each bit in the USB\_INTSTS register to determine the priority of these events in the interrupt service routine. After handling the interrupt of the corresponding bits, the interrupt flags are cleared. At the end of the service routine, another interrupt will be requested to handle the remaining interrupts.

To avoid spurious clearing of some bits, it is recommended that users use load instruction, and all bits, that must not be altered, are written with '1', while all bits, that need to be cleared, are written with '0'. Read-modify-write cycles should be avoided for this register because hardware may need to set some bits between the read and the write operations, and these bits will be cleared during the next write.

| Bit    | Name    | Туре  | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15 | CTFRF   | r     | Correct transfer<br>This bit is set by the hardware to indicate that an endpoint<br>successfully completes a transaction; using the DIR and EPT_ID bits,<br>software can identify which endpoint completes the transaction<br>successfully.<br>This bit is read-only.                                                                                                                                      |
| Bit 14 | PMOVERF | rc_w0 | Packet memory area over/underrun<br>This bit is set by hardware if the microcontroller cannot respond to an<br>USB memory request in time for a long while. The USB peripheral<br>handles this event in the following way: During reception, an ACK<br>handshake packet is not sent; during transmission, a bit-stuff error is<br>forced on the transmitted stream; in both cases, the host will retry the |

Each bit is detailed as follows:



|        |       |       | transaction. The PMOVERF interrupt never occur during normal                |
|--------|-------|-------|-----------------------------------------------------------------------------|
|        |       |       | operations. Since the failed transaction will be retried by the host, the   |
|        |       |       | application software has the chance to speed-up device operations           |
|        |       |       | during this interrupt handling, to be ready for the next transaction retry; |
|        |       |       | however, this interrupt is not generated during isochronous transfers       |
|        |       |       | ("retry" is not supported in isochronous transaction), so this may lead     |
|        |       |       | to a loss of data.                                                          |
|        |       |       | This bit is $r/w$ , but only '0' can be written; writing '1' has no effect. |
|        |       |       | Error                                                                       |
|        |       |       | This flag is set by hardware whenever one of the errors listed below        |
|        |       |       | occurs. NANS: No answer. The timeout for a host response expires.           |
|        |       |       | CRC: Cyclic redundancy check error. One of the received CRCs in the         |
|        |       |       | token or in the data is wrong.                                              |
|        |       |       | BST: Bit stuffing error. A bit stuffing error is detected in PID, data,     |
|        | ERRF  | rc_w0 | and/or CRC.                                                                 |
|        |       |       | FVIO: Framing format violation. A non-standard frame is received            |
| Bit 13 |       |       | (e.g. EOP not in the right place, wrong token sequence, etc.).              |
|        |       |       | The USB software can usually ignore these errors, since the USB             |
|        |       |       | peripheral and the PC host will activate retransmission in case of          |
|        |       |       | errors.                                                                     |
|        |       |       | This interrupt can be useful at the software development phase, to          |
|        |       |       | monitor the quality of transmission over the USB bus and to flag            |
|        |       |       | possible errors to users (e.g. loose connector, serious noisy               |
|        |       |       | environment, broken conductor in the USB cable, and so on).                 |
|        |       |       | This bit is $r/w$ , but only '0' can be written; writing '1' has no effect. |
|        | WKUPF |       | Wakeup                                                                      |
|        |       |       | This bit is set by the hardware when wakeup signal is detected in           |
| Bit 12 |       | rc_w0 | suspend mode. This event clears the LPWR bit in the CTRL register           |
|        |       |       | and activates the USB_WAKEUP line, notifying the rest parts of the          |
|        |       |       | device (e.g. wakeup unit) of the start of the resume process. This bit      |
|        |       |       | is r/w, but only '0' can be written; writing '1' has no effect.             |
|        | •     | •     |                                                                             |



| Bit 11 | SUSPF | rc_w0 | Suspend mode request<br>This bit is set by the hardware when no traffic is received for 3 ms,<br>indicating a suspend mode request from the USB bus. The suspend<br>condition check is enabled immediately after any USB reset, and it is<br>disabled by the hardware in the suspend mode (FSUSP = 1) until the<br>end of a resume sequence.<br>This bit is r/w, but only '0' can be written; writing '1' has no effect.                                                                                                                                                                                                                                                                              |
|--------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 10 | RSTF  | rc_w0 | USB reset request<br>This bit is set when the USB peripheral detects USB reset signal input.<br>The USB peripheral resets its internal protocol state machine and<br>responds to the signal by generating a reset interrupt if interrupt is<br>enabled. Reception and transmission on USB are disabled until this bit<br>is cleared. All configuration registers are not reset, unless the<br>application clears these registers; this ensures that the USB transaction<br>can still be successfully completed after the reset. The device addresses<br>and endpoint registers, however, are reset by an USB reset event.<br>This bit is r/w, but only '0' can be written; writing '1' has no effect. |
| Bit 9  | SOFF  | rc_w0 | Start of frame<br>This bit signals the beginning of a new USB frame, and it is set by<br>hardware when a SOF packet on the USB bus is detected by the USB<br>peripheral. The interrupt service routine can monitor the SOF events<br>to complete 1 ms synchronization with the host and to safely read the<br>updated content after the register receives SOF packet (This could be<br>very useful for isochronous transfers).<br>This bit is r/w, but only '0' can be written; writing '1' has no effect.                                                                                                                                                                                            |
| Bit 8  | ESOF  | rc_w0 | Expected start of frame<br>This bit is set by the hardware when an SOF packet is expected but not<br>received. The host sends an SOF packet each ms, but if the USB<br>peripheral does not receive it properly, the suspend timer will issue this<br>interrupt. If three consecutive ESOF interrupts are generated,<br>i.e. three SOF packets are lost consecutively, a SUSPF interrupt will be                                                                                                                                                                                                                                                                                                       |



| Bit 7:5       -       -       Reserved         Bit 7:5       -       -       Reserved         Direction of transaction       This bit is written by the hardware according to the transaction direct after the transaction completion generates interrupt request. If the bit = 0, the CTFR_TX bit related to the interrupting endpoint is indicating the completion of an IN transaction (data transmitted by USB peripheral to the host PC). If the DIR bit = 1, the CTFR_RX bit related to the interrupting the completion an OUT transaction (data received by the USB peripheral from the PC). If the CTFR_TX bit is set at the same time, it indicates two perior transactions (IN and OUT) are waiting to be processed. This informa can be used by the application software to access the USB_EPTN related to the triggering transaction since it represents the direction the pending interrupt. This bit is read-only.         Endpoint identifier       These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt       | ,       |             |   |                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------|---|--------------------------------------------------------------------------------|
| Bit 7:5       -       Reserved         Bit 7:5       -       Reserved         Direction of transaction       This bit is written by the hardware according to the transaction direct after the transaction completion generates interrupt request. If the bit = 0, the CTFR_TX bit related to the interrupting endpoint is indicating the completion of an IN transaction (data transmitted by USB peripheral to the host PC). If the DIR bit = 1, the CTFR_RX related to the interrupting endpoint is set, indicating the completion an OUT transaction (data received by the USB peripheral from the PC). If the CTFR_TX bit is set at the same time, it indicates two pend transactions (IN and OUT) are waiting to be processed. This informa can be used by the application software to access the USB_EPTN related to the triggering transaction since it represents the direction the pending interrupt. This bit is read-only.         Endpoint identifier       These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt |         |             |   | generated. Even if missing SOF packets occur while the suspend timer           |
| Bit 7:5       -       Reserved         Bit 7:5       -       Reserved         Direction of transaction       This bit is written by the hardware according to the transaction direct after the transaction completion generates interrupt request. If the bit = 0, the CTFR_TX bit related to the interrupting endpoint is indicating the completion of an IN transaction (data transmitted by USB peripheral to the host PC). If the DIR bit = 1, the CTFR_RX related to the interrupting endpoint is set, indicating the completion an OUT transaction (data received by the USB peripheral from the PC). If the CTFR_TX bit is set at the same time, it indicates two pend transactions (IN and OUT) are waiting to be processed. This informa can be used by the application software to access the USB_EPTN related to the triggering transaction since it represents the direction the pending interrupt. This bit is read-only.         Endpoint identifier       These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt |         |             |   | is not yet locked, this bit is still set. This bit is r/w, but only `0' can be |
| Bit 4       DIR       r       Direction of transaction         Bit 4       DIR       r       related to the interrupting endpoint is indicating the completion of an IN transaction (data transmitted by USB peripheral to the host PC). If the DIR bit = 1, the CTFR_RX         r       related to the interrupting endpoint is set, indicating the completion (data received by the USB peripheral from the fPC). If the CTFR_TX bit is set at the same time, it indicates two period transactions (IN and OUT) are waiting to be processed. This informa can be used by the application software to access the USB_EPTN related to the triggering transaction since it represents the direction the pending interrupt. This bit is read-only.         Endpoint identifier       These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt                                                                                                                                                                                       |         |             |   | written; writing `1' has no effect.                                            |
| Bit 4DIRrThis bit is written by the hardware according to the transaction direct<br>after the transaction completion generates interrupt request. If the<br>bit = 0, the CTFR_TX bit related to the interrupting endpoint is<br>indicating the completion of an IN transaction (data transmitted by<br>USB peripheral to the host PC). If the DIR bit = 1, the CTFR_RX<br>related to the interrupting endpoint is set, indicating the completion<br>an OUT transaction (data received by the USB peripheral from the P<br>PC). If the CTFR_TX bit is set at the same time, it indicates two pend<br>transactions (IN and OUT) are waiting to be processed. This informa<br>can be used by the application software to access the USB_EPTN<br>related to the triggering transaction since it represents the direction<br>the pending interrupt. This bit is read-only.Endpoint identifier<br>These bits are written by the hardware according to the endpoint of<br>interrupt request after the transaction completion generates interrupt                                                                           | Bit 7:5 | -           | - | Reserved                                                                       |
| Bit 4DIRrBit 4DIRrrelated to the interrupting endpoint is indicating the completion of an IN transaction (data transmitted by USB peripheral to the host PC). If the DIR bit = 1, the CTFR_RX related to the interrupting endpoint is set, indicating the completion an OUT transaction (data received by the USB peripheral from the PC). If the CTFR_TX bit is set at the same time, it indicates two period transactions (IN and OUT) are waiting to be processed. This information can be used by the application software to access the USB_EPTN related to the triggering transaction since it represents the direction the pending interrupt. This bit is read-only.Endpoint identifier<br>These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                                                                                        |         |             |   | Direction of transaction                                                       |
| Bit 4       DIR       r         Bit 4       DIR       r         related to the interrupting endpoint is set, indicating the completion of an IN transaction (data transmitted by USB peripheral to the host PC). If the DIR bit = 1, the CTFR_RX related to the interrupting endpoint is set, indicating the completion an OUT transaction (data received by the USB peripheral from the PC). If the CTFR_TX bit is set at the same time, it indicates two pend transactions (IN and OUT) are waiting to be processed. This informa can be used by the application software to access the USB_EPTN related to the triggering transaction since it represents the direction the pending interrupt. This bit is read-only.         Endpoint identifier       These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                               |         |             |   | This bit is written by the hardware according to the transaction direction     |
| Bit 4       DIR       r       indicating the completion of an IN transaction (data transmitted by USB peripheral to the host PC). If the DIR bit = 1, the CTFR_RX related to the interrupting endpoint is set, indicating the completion an OUT transaction (data received by the USB peripheral from the PC). If the CTFR_TX bit is set at the same time, it indicates two pend transactions (IN and OUT) are waiting to be processed. This informa can be used by the application software to access the USB_EPTN related to the triggering transaction since it represents the direction the pending interrupt. This bit is read-only.         Endpoint identifier       These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                                                                                                              |         |             |   | after the transaction completion generates interrupt request. If the DIR       |
| Bit 4       DIR       r       USB peripheral to the host PC). If the DIR bit = 1, the CTFR_RX related to the interrupting endpoint is set, indicating the completion an OUT transaction (data received by the USB peripheral from the PC). If the CTFR_TX bit is set at the same time, it indicates two pend transactions (IN and OUT) are waiting to be processed. This informatican be used by the application software to access the USB_EPTN related to the triggering transaction since it represents the direction the pending interrupt. This bit is read-only.         Endpoint identifier       These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                                                                                                                                                                                 |         |             |   | bit = 0, the CTFR_TX bit related to the interrupting endpoint is set,          |
| Bit 4       DIR       r       related to the interrupting endpoint is set, indicating the completion an OUT transaction (data received by the USB peripheral from the PC). If the CTFR_TX bit is set at the same time, it indicates two pend transactions (IN and OUT) are waiting to be processed. This informal can be used by the application software to access the USB_EPTN related to the triggering transaction since it represents the direction the pending interrupt. This bit is read-only.         Endpoint identifier       These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |             |   | indicating the completion of an IN transaction (data transmitted by the        |
| an OUT transaction (data received by the USB peripheral from the h<br>PC). If the CTFR_TX bit is set at the same time, it indicates two pend<br>transactions (IN and OUT) are waiting to be processed. This informal<br>can be used by the application software to access the USB_EPTN<br>related to the triggering transaction since it represents the direction<br>the pending interrupt. This bit is read-only.<br>Endpoint identifier<br>These bits are written by the hardware according to the endpoint of<br>interrupt request after the transaction completion generates interr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |             |   | USB peripheral to the host PC). If the DIR bit = 1, the CTFR_RX bit            |
| PC). If the CTFR_TX bit is set at the same time, it indicates two pend<br>transactions (IN and OUT) are waiting to be processed. This informatic<br>can be used by the application software to access the USB_EPTN<br>related to the triggering transaction since it represents the direction<br>the pending interrupt. This bit is read-only.         Endpoint identifier         These bits are written by the hardware according to the endpoint of<br>interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Bit 4   | DIR         | r | related to the interrupting endpoint is set, indicating the completion of      |
| transactions (IN and OUT) are waiting to be processed. This information can be used by the application software to access the USB_EPTN related to the triggering transaction since it represents the direction the pending interrupt. This bit is read-only.         Endpoint identifier         These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |             |   | an OUT transaction (data received by the USB peripheral from the host          |
| can be used by the application software to access the USB_EPTN         related to the triggering transaction since it represents the direction         the pending interrupt. This bit is read-only.         Endpoint identifier         These bits are written by the hardware according to the endpoint of         interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |             |   | PC). If the CTFR_TX bit is set at the same time, it indicates two pending      |
| related to the triggering transaction since it represents the direction<br>the pending interrupt. This bit is read-only.<br>Endpoint identifier<br>These bits are written by the hardware according to the endpoint of<br>interrupt request after the transaction completion generates interr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |             |   | transactions (IN and OUT) are waiting to be processed. This information        |
| the pending interrupt. This bit is read-only.         Endpoint identifier         These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |             |   | can be used by the application software to access the USB_EPTN bits            |
| Endpoint identifier         These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |             |   | related to the triggering transaction since it represents the direction of     |
| These bits are written by the hardware according to the endpoint of interrupt request after the transaction completion generates interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |             |   | the pending interrupt. This bit is read-only.                                  |
| interrupt request after the transaction completion generates interr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |             |   | Endpoint identifier                                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |             |   | These bits are written by the hardware according to the endpoint of the        |
| request. If several endpoint transactions are pending at the same ti                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |             |   | interrupt request after the transaction completion generates interrupt         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |             |   | request. If several endpoint transactions are pending at the same time,        |
| the hardware writes the endpoint with the highest priority. The priority                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |             |   | the hardware writes the endpoint with the highest priority. The priority       |
| is defined in the following way: Isochronous and double-buffered b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |             |   | is defined in the following way: Isochronous and double-buffered bulk          |
| Bit 3:0 EPT_ID[3:0] r endpoints are considered the highest priority, and other endpoints                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Bit 3:0 | EPT_ID[3:0] | r | endpoints are considered the highest priority, and other endpoints are         |
| lower priority. If several endpoints with the same priority are reques                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |             |   | lower priority. If several endpoints with the same priority are requesting     |
| an interrupt, then the priority is determined by the number of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |             |   | an interrupt, then the priority is determined by the number of the             |
| endpoint; Endpoint 0 has the highest priority, i.e. the smaller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |             |   | endpoint; Endpoint 0 has the highest priority, i.e. the smaller the            |
| number, the higher the priority. The application software can order                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |             |   | number, the higher the priority. The application software can order the        |
| endpoint requests according to this priority scheme.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |             |   | endpoint requests according to this priority scheme.                           |
| These bits are read-only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |         |             |   | These bits are read-only.                                                      |



#### **19.4.1.3 USB Frame Number Register (USB\_FRNUM)**

Address offset: 0x48

Reset value: 0x0XXX, where X is an undefined value.

| Bit       | Name        | Туре | Description                                                                                                                                                                                                                                                                                                    |
|-----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15    | DPSTS       | r    | Receive data + line status<br>This bit can be used to observe the received data plus line status<br>and to monitor the occurrence of wakeup event at pending state.                                                                                                                                            |
| Bit 14    | DMSTS       | r    | Receive data - line status<br>This bit can be used to observe the received data minus line status<br>and to monitor the occurrence of wakeup event at pending state.                                                                                                                                           |
| Bit 13    | LCK         | r    | Locked<br>This bit is set by the hardware when at least two consecutive SOF<br>packets are received after the end of an USB reset condition or<br>after the end of an USB resume sequence. Once locked, the frame<br>timer stops counting, and it resumes counting after an USB reset<br>or USB suspend event. |
| Bit 12:11 | LSOF[1:0]   | r    | Lost SOF<br>When an ESOF event occurs, these bits are written by the<br>hardware with the number of lost SOF packets. At the reception of<br>another SOF packet, these bits are cleared.                                                                                                                       |
| Bit 10:0  | FRNUM[10:0] | r    | Frame number<br>This bit field contains the 11-bit frame number in the last received<br>SOF packet. The frame number is incremented at each frame sent<br>by the host, and this is very useful for isochronous transfers. This<br>bit field is updated at the generation of an SOF interrupt.                  |

#### **19.4.1.4 USB Device Address Register (USB\_DEVADR)**

Address offset: 0x4C

Reset value: 0x0000



| Bit     | Name     | Туре | Description                                                           |
|---------|----------|------|-----------------------------------------------------------------------|
|         |          |      | Enable function                                                       |
|         | EN       | rw   | This bit is set by the software to enable the USB device. If this bit |
| Bit 7   |          | TW   | is `0', the USB peripheral stops working, ignores the settings of all |
|         |          |      | the registers, and do not respond to any USB communication.           |
| Bit 6:0 | ADR[6:0] | rw   | Device address                                                        |
|         |          |      | These bits contain the USB function address assigned by the host      |
|         |          |      | during the enumeration process. Both this field and the endpoint      |
|         |          |      | address (EPTADR) field must match with the address information        |
|         |          |      | contained in USB token, to handle a transaction to the required       |
|         |          |      | endpoint successfully.                                                |

# 19.4.1.5 USB Packet Buffer Description Table Address Register (USB\_BUFTBL)

Address offset: 0x50

Reset value: 0x0000

| Bit      | Name      | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|-----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:3 | ADR[15:3] | rw   | Buffer table address<br>These bits contain the start addresses of the buffer description<br>table inside the dedicated packet memory. This table describes the<br>buffer location and the size of each endpoint, and it must be<br>aligned to an 8-byte boundary (the 3 least significant bits are<br>always 000). At the beginning of every transaction, the USB<br>peripheral reads the table related to the addressed endpoint, to<br>obtain its buffer start location and the buffer size. |
| Bit 2:0  | -         | -    | Reserved. Forced to be '0' by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### 19.4.1.6 USB SOF Control Register (USB\_SOFEN)

Address offset: 0x60

Reset value: 0x0000



| Bit      | Name     | Туре | Description                                                                                   |
|----------|----------|------|-----------------------------------------------------------------------------------------------|
| Bit 15:2 |          | -    | Reserved                                                                                      |
| Bit 1    | PUO      | rw   | DP pullup off<br>0: DP pullup is enabled.<br>1: DP pullup is disabled.                        |
| Bit 0    | SOFOUTEN | rw   | SOF output enable<br>0: SOF pulse is not outputted.<br>1: SOF pulse is outputted to the pins. |

#### **19.4.2 Endpoint Registers**

The number of these registers is determined by the number of endpoints supported by the USB peripheral. The USB peripheral supports up to 8 bidirectional endpoints. Each USB device must support a control endpoint, of which address (the EPTADR bit) must be set to 0. Different endpoints must use different numbers; otherwise, endpoints will behave in an undefined way. For each endpoint, there is a corresponding USB\_EPTn register available to store the endpoint specific information.

#### 19.4.2.1 USB Endpoint n Register (USB\_EPTn), n = [0...7]

Address offset:  $0x00 \sim 0x1C$ 

#### Reset value: 0x0000

When the USB peripheral receives reset signal from the USB bus, or the FRST bit in the CTLR register is set, the USB peripheral will perform a reset. All the bits are reset except for the CTFR\_RX and CTFR\_TX bits, which are kept unchanged to handle the following transactions. Each endpoint has its corresponding USB\_EPTn register, where n is the endpoint identifier.

Read-modify-write cycles on these registers should be avoided because some bits may be set by the hardware between the read and the write operations; the next write will then modify these bits again, causing the application to miss the related operations. Therefore, all these bits have an 'invariant' value that must be used whenever their modification is not required. It is recommended that users modify these registers with a load instruction to prevent the application from modifying bits that do not need to be modified.



| Bit       | Name        | Туре  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------|-------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15    | CTFR_RX     | rc_w1 | Correct transfer for reception<br>This bit is set by the hardware when an OUT/SETUP transaction<br>is successfully completed; software can only clear this bit. If the<br>CTFR_IEN bit is set accordingly, a related interrupt is generated.<br>The type of the transaction, OUT or SETUP, can be determined<br>from the SETUP bit described below. A transaction ended with a<br>NAK or STALL handshake does not set this bit, since no data is<br>actually transferred.<br>This bit is r/w, but only 0 can be written; writing 1 has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 14    | DTOG_RX     | t     | Data toggle for reception transfers<br>If the endpoint is not isochronous, this bit is set by hardware to<br>indicate the expected value of the data toggle bit (0 = DATA0, 1<br>= DATA1) for the next data packet to be received. After receiving<br>correct data packet of PID, the USB peripheral sends the ACK<br>handshake and toggles this bit; if the endpoint is defined as a<br>control one, hardware clears this bit at the reception of a SETUP<br>packet.<br>If the endpoint is double-buffered, this bit is also used to<br>support the double buffer swapping. If the endpoint is<br>isochronous, since only DATA0 is sent, this bit is used only to<br>support double buffer swapping without toggling. Hardware sets<br>this bit right after the end of data packet reception, since no<br>handshake is used for isochronous transfers.<br>Software can initialize this bit (initialization is necessary when<br>the endpoint is not a control one) or toggle this bit for special<br>usages.<br>This bit is r/w, but writing 0 has not effect; writing 1 toggles this<br>bit. |
| Bit 13:12 | STS_RX[1:0] | t     | Status bits for reception transfers<br>This bit is used to indicate the current status of the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |



|          |               |    | After a correct OUT or SETUP transaction is completed                                      |
|----------|---------------|----|--------------------------------------------------------------------------------------------|
|          |               |    | (CTFR_RX=1), hardware will automatically set this bit at NAK                               |
|          |               |    | state, allowing application to have enough time to answer the                              |
|          |               |    | next data packet after finishing the current transfer.                                     |
|          |               |    | Double-buffered bulk endpoints implement a special transaction                             |
|          |               |    | flow control, which controls the transfer status based upon the                            |
|          |               |    | buffer availability condition. If the endpoint is defined as                               |
|          |               |    | isochronous, its status can be only "VALID" or "DISABLED", so                              |
|          |               |    | the hardware cannot change its status after a successful                                   |
|          |               |    | transaction.                                                                               |
|          |               |    | If the software sets these bits to "STALL" or "NAK", the USB $% \mathcal{T}_{\mathcal{T}}$ |
|          |               |    | peripheral's responding behavior is undefined.                                             |
|          |               |    | This bit is r/w, but writing 0 has not effect; writing 1 toggles                           |
|          |               |    | these bits.                                                                                |
|          | SETUP         | t  | Setup transaction completed                                                                |
|          |               |    | This bit is set by the hardware when the USB peripheral receives                           |
|          |               |    | a successful SETUP transaction. This bit is used only by control                           |
|          |               |    | endpoints. It must be examined by the application after a                                  |
|          |               |    | successful receive transaction (CTFR_RX = 1) to determine                                  |
| Bit 11   |               |    | whether this transaction is the SETUP type. To prevent next                                |
|          |               |    | incoming tokens from modifying this bit while the interrupt                                |
|          |               |    | service routine is handling SETUP transaction, this bit is kept                            |
|          |               |    | frozen while CTFR_RX is at 1; it can only be changed when                                  |
|          |               |    | CTFR_RX is at 0.                                                                           |
|          |               |    | This bit is read-only.                                                                     |
|          |               |    | Endpoint type                                                                              |
|          |               |    | These bits are used to configure the current type of endpoint. All                         |
|          | EPT_TYPE[1:0] | rw | USB devices must have at least one control endpoint of which                               |
| Bit 10:9 |               |    | address is 0; there may be other control endpoints if required.                            |
|          |               |    | Only control endpoints cab handle SETUP transactions, which are                            |
|          |               |    | ignored by endpoints of other kinds. SETUP transactions cannot                             |
|          |               |    |                                                                                            |



| Bit 6 |             | L     | If the endpoint is non-isochronous, this bit contains the required     |
|-------|-------------|-------|------------------------------------------------------------------------|
| Rit 6 | DTOG_TX     | rc_w0 | Data Toggle for transmission transfers                                 |
|       |             |       | only 0 can be written; writing 1 has no effect.                        |
|       |             |       | be set, since no data is actually transferred. This bit is r/w, but    |
|       |             |       | answers with a NAK or STALL handshake, then this bit will not          |
|       |             |       | this event is handled. At the end of IN transaction, if the host       |
| Bit 7 | CTFR_TX     |       | if the CTFR_IEN bit is set. Software needs to clear this bit after     |
|       |             |       | successfully completed; corresponding interrupts are generated         |
|       |             |       | This bit is set by the hardware when an IN transaction is              |
|       |             |       | Correct transfer for transmission                                      |
|       |             |       | can contain data with any lengths, as required.                        |
|       | EPT_SUBTYPE | rw    | protocol errors. When STATUS_OUT is cleared, OUT transactions          |
|       |             |       | used for control endpoints; it is useful for the application to detect |
|       |             |       | zero, will be answered "STALL" by the device. This function is only    |
|       |             |       | host; in this case, all OUT transactions, of which length is non-      |
| Bit 8 |             |       | USB peripheral is expecting a status of OUT transaction from the       |
|       |             |       | STATUS_OUT: This bit is set by the software to indicate that the       |
|       |             |       | software to enable the double-buffering feature for bulk endpoint.     |
|       |             |       | configured by the EPT_TYPE bits. DBL_BUF: This bit is set by the       |
|       |             |       | The definition of this bit depends on the endpoint type                |
|       |             |       | Endpoint kind                                                          |
| -     |             |       | they differ only in the handling of the EPT_SUBTYPE bit.               |
|       |             |       | Bulk and interrupt endpoints have very similar behaviors, and          |
|       |             |       | the same way as the normal endpoint.                                   |
|       |             |       | correctly. An OUT transaction of a control endpoint is handled in      |
|       |             |       | successfully, transferring data and issuing a CTR interrupt            |
|       |             |       | is defined as STALL, then the SETUP packet will be accepted            |
|       |             |       | will not answer, generating a receive error. If the control endpoint   |
|       |             |       | as NAK when a SETUP transaction is received, the USB peripheral        |
|       |             |       | be answered with NAK or STALL. If a control endpoint is defined        |



|         |             |    | value of the data toggle bit ( $0 = DATA0$ , $1 = DATA1$ ) for the     |
|---------|-------------|----|------------------------------------------------------------------------|
|         |             |    | next data packet to be transmitted. After a successful data            |
|         |             |    | packet transmission, if the USB peripheral receives the ACK            |
|         |             |    | handshake from the host, this bit will be toggled. If the endpoint     |
|         |             |    | is defined as a control one, this bit is set at the reception of a     |
|         |             |    | correct SETUP PID. If the endpoint is double-buffered, this bit is     |
|         |             |    | also used to support packet buffer swapping.                           |
|         |             |    | If the endpoint is isochronous, since only DATA0 is sent, this bit     |
|         |             |    | is used only to support double buffer swapping. Hardware sets          |
|         |             |    | this bit right after the end of data packet reception, since no        |
|         |             |    | handshake is used for isochronous transfers. Software can              |
|         |             |    | initialize this bit (initialization is necessary when the endpoint is  |
|         |             |    | not a control one) or configure this bit for special usages.           |
|         |             |    | This bit is r/w, but writing 0 has no effect; writing 1 toggles this   |
|         |             |    | bit.                                                                   |
|         |             |    | Status bits for transmission transfers                                 |
|         |             | t  | This bit is used to indicate the current status of the endpoint;       |
|         |             |    | Table 19-6 lists all the status. The application can toggle these bits |
|         |             |    | to initialize the status information. After a correct IN transaction   |
|         |             |    | is completed (CTFR_TX=1), hardware will automatically set this         |
|         |             |    | bit at NAK state, allowing application to have enough time for the     |
|         |             |    | following data transfer.                                               |
|         |             |    | Double-buffered bulk endpoints implement a special transaction         |
| Bit 5:4 | STS_TX[1:0] |    |                                                                        |
|         |             |    | flow control, which control s the transfer status based upon the       |
|         |             |    | buffer availability condition. If the endpoint is defined as           |
|         |             |    | isochronous, its status can only be "VALID" or "DISABLED", so the      |
|         |             |    | hardware cannot change its status after a successful transaction.      |
|         |             |    | If the software sets these bits to "STALL" or "NAK", the USB           |
|         |             |    | peripheral's responding behavior is undefined.                         |
|         |             |    | This bit is r/w, but writing 0 has not effect; writing 1 toggles these |
|         |             |    | bits.                                                                  |
| Bit 3:0 | EPTADR[3:0] | rw | Endpoint address                                                       |
|         |             |    |                                                                        |



Hangzhou Vango Technologies, Inc.

|  | Software must write these 4 bits; before enabling the |
|--|-------------------------------------------------------|
|  | corresponding endpoint, its address must be defined.  |

#### Table 19-6 Reception Status Encoding

| STS_RX[1:0] | Description                                                              |
|-------------|--------------------------------------------------------------------------|
| 00          | DISABLED: All reception requests addressed to this endpoint are ignored. |
| 01          | STALL: All reception requests result in a STALL handshake.               |
| 10          | NAK: All reception requests result in a NAK handshake.                   |
| 11          | VALID: This endpoint is enabled for reception.                           |

#### Table 19-7 Endpoint Type Encoding

| EPT_TYPE[1:0] | Description               |
|---------------|---------------------------|
| 00            | BULK: Bulk endpoint       |
| 01            | CTRL: Control endpoint    |
| 10            | ISO: Isochronous endpoint |
| 11            | INT: Interrupt endpoint   |

#### Table 19-8 Endpoint Kind Meaning

| EPT_T | /PE[1:0] | EPT_SUBTYPE Definition          |
|-------|----------|---------------------------------|
| 00    | BULK     | DBL_BUF: Double-buffer endpoint |
| 01    | CTRL     | STATUS_OUT                      |
| 10    | ISO      | Unused                          |
| 11    | INT      | Unused                          |

#### Table 19-9 Transmission Status Encoding

| STS_TX[1:0] | Description                                                        |
|-------------|--------------------------------------------------------------------|
| 00          | DISABLED: All transmission requests addressed to this endpoint are |
|             | ignored.                                                           |
| 01          | STALL: All transmission requests result in a STALL handshake.      |
| 10          | NAK: All transmission requests result in a NAK handshake.          |
| 11          | VALID: This endpoint is enabled for transmission.                  |



#### **19.4.3 Buffer Description Table Registers**

Although the buffer description table is located inside the packet buffer memory, it can be regarded as additional registers used to configure the location and size of the packet buffers shared by the USB peripheral and the microcontroller core. Since APB1 bus is addressed by 32 bits, all packet memory locations are accessed by 32-bit aligned address, instead of the actual memory location address of the USB\_BUFTBL register and the buffer description table.

In the following sections, two location addresses are introduced: The one to be used by application software while accessing the packet memory, and the other is the local one associated with the USB peripheral access. To obtain the correct memory address in the microcontroller, the packet memory address used by the application must be multiplied by 2. The first packet memory location is 0x40006000/ 0x40007800. The buffer description table entry associated with the USB\_EPTn registers is described below.

## 19.4.3.1 Transmission Buffer Address Register n

#### (USB\_ADRn\_TX)

Address offset: [USB\_BUFTBL] x 2 + n x 16

USB local address: [USB\_BUFTBL] + n x 8

| Bit      | Name          | Туре | Description                                                                                                                                                    |
|----------|---------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:1 | ADRn_TX[15:1] | rw   | Transmission buffer address<br>These bits point to the starting address of the packet buffer<br>containing data to be transmitted for the next IN transaction. |
| Bit 0    |               | -    | Must always be written as '0' since all packet buffers must be word-aligned.                                                                                   |

# 19.4.3.2 Transmission Byte Count Register n (USB\_CNTn\_TX)

Address offset: [USB\_BUFTBL] x 2 + n x 16 + 4

USB local address: [USB\_BUFTBL] + n x 8 + 2



| Bit       | Name         | Туре | Description                                                                                                         |
|-----------|--------------|------|---------------------------------------------------------------------------------------------------------------------|
| Bit 15:10 | -            | res  | These bits are ignored by the USB peripheral since packet size is limited by USB specifications to 1023 bytes.      |
| Bit 9:0   | CNTn_TX[9:0] | rw   | Transmission byte count<br>These bits contain the number of bytes to be transmitted for<br>the next IN transaction. |

Note: Double-buffered and isochronous IN endpoints have two USB\_CNTn\_Tx registers:

USB\_CNTn\_TX\_1 and USB\_CNTn\_TX\_0.

#### 19.4.3.3 Reception Buffer Address Register n

### (USB\_ADRn\_RX)

Address offset: [USB\_BUFTBL] x 2 + n x 16 + 8

USB local address: [USB\_BUFTBL] + n x 8 + 4

| Bit      | Name           | Туре | Description                                                     |
|----------|----------------|------|-----------------------------------------------------------------|
| Bit 15:1 | ADRn_RX[15: 1] | rw   | Reception buffer address                                        |
|          |                |      | These bits point to the starting address of the packet buffer,  |
|          |                |      | which contain the data for the next OUT/SETUP transaction.      |
| Bit 0    | -              | -    | This bit must always be written as '0' since all packet buffers |
|          |                |      | must be word-aligned.                                           |

#### **19.4.3.4** Reception Byte Count Register n (USB\_CNTn\_RX)

Address offset: [USB\_BTABLE] x 2 + n x 16 + 12 USB local address: [USB\_BTABLE] + n x 8 + 6

This register is used to store two different values, both required during packet reception. The most significant 6 bits define the reception buffer size to allow buffer overflow detection; while the least significant 10 bits are used by the USB peripheral to give the actual number of received bytes. Due to the restrictions on the number of available bits, buffer size is represented by the number of allocated memory blocks, and the block size is determined by the required buffer size. The size of allocated buffer is defined during the enumeration process according to the maxPacketSize parameter value of the endpoint description (Please refer to "Universal Serial Bus 2.0 Specification" for more details).



| Bit       | Name         | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|--------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15    | BLKSIZE:     | rw   | Block size<br>This bit defines the size of memory block used to determine<br>the allocated buffer area.<br>If BLKSIZE = 0, the size of memory block is 2 bytes, so the<br>allocated buffer size ranges from 2 to 62 bytes.<br>If BLKSIZE = 1, the size of memory block is 32 bytes, which<br>allows to reach the maximum packet length defined by USB<br>specifications, so the allocated buffer size ranges from 32 to<br>512/768 bytes, which is the maximum packet size allowed by<br>USB standard specifications. |
| Bit 14:10 | NUM_BLK[4:0] | rw   | Number of blocks<br>These bits define the number of memory blocks allocated,<br>which then determining the size of the packet buffer finally<br>being used.                                                                                                                                                                                                                                                                                                                                                           |
| Bit 9:0   | CNTn_RX[9:0] | rw   | Reception byte count<br>These bits are written by the USB peripheral to record the<br>number of bytes received by the endpoint during the last<br>OUT/SETUP transaction.                                                                                                                                                                                                                                                                                                                                              |

Note: Double-buffered and isochronous IN endpoints have two USB\_CNTn\_RX registers: USB\_CNTn\_RX\_1 and USB\_CNTn\_TX\_0.

| Table 19-9 Definition | of Allocated | Buffer | Memory |
|-----------------------|--------------|--------|--------|
|-----------------------|--------------|--------|--------|

| NUM_BLK[4:0] Value | Memory allocated when BLKSIZE = 0 | Memory allocated when BLKSIZE = 1 |
|--------------------|-----------------------------------|-----------------------------------|
| 00000              | Not allowed                       | 32 bytes                          |
| 00001              | 2 bytes                           | 64 bytes                          |
| 00010              | 4 bytes                           | 96 bytes                          |
| 00011              | 6 bytes                           | 128 bytes                         |
|                    |                                   |                                   |
| 01111              | 30 bytes                          | 512 bytes                         |
| 10000              | 32 bytes                          | 544 bytes (Note)                  |
| ango               | Hangzhou Vango Technologie        | es, Inc. 774 / 782                |

| 10001 | 34 bytes | 576 bytes (Note)  |  |
|-------|----------|-------------------|--|
| 10010 | 36 bytes | 608 bytes (Note)  |  |
|       |          |                   |  |
| 10111 | 46 bytes | 768 bytes (Note)  |  |
| 11000 | 48 bytes | 800 bytes (Note)  |  |
|       |          |                   |  |
| 11110 | 60 bytes | 992 bytes (Note)  |  |
| 11111 | 62 bytes | 1024 bytes (Note) |  |

# 20 MCU Debug (MCUDBG)

## 20.1 Introduction

V84XXX are built with the Cortex<sup>®</sup>-M4F core, which contains hardware extensions for advanced debugging features. The debug extensions allow the core to be stopped either on a given instruction fetch (breakpoint) or data access (watchpoint). When stopped, the core's internal state and the system's external state can be examined. Once the examination is completed, the core and the system can be restored, and the program execution will resume.

When the V84XXX microcontroller is connected to the debugger and begins to debug, the debugger implements debugging operation with the hardware debug module.

Two interfaces for debug are available:

- Serial wire
- JTAG debug port

Figure 20-1 Block Diagram of V84XXX-Level and Cortex<sup>®</sup>-M4F-Level Debug Support





The ARM Cortex<sup>®</sup>-M4F core provides integrated on-chip debug support. Please refer to the following:

- Cortex<sup>®</sup>-M4 Technical Reference Manual (TRM)
- ARM Debug Interface V5
- ARM CoreSight Design Kit (Revision r1p0) Technical Reference Manual

MCUDBG module component helps the debugger to debug low-power mode, timer, I<sup>2</sup>C, bxCAN, WWDG, and IWDG. When the corresponding bits are set, MCUDBG provides clocks or keeps counter timers, WWDG, IWDG, CAN, or I<sup>2</sup>C, at the current state in low-power mode. The MCU debug component helps the debugger provide supports for:

- Low-power mode
- $\bullet$  Clock control for timers, watchdog,  $I^2C,$  and bxCAN during a breakpoint
- ID code



## **20.2 Function Overview**

#### 20.2.1 Debug Support for Low-power Mode

To enter low-power mode, the instruction of WFI and WFE are executed. MCU supports several lowpower modes, which can either deactivate the CPU clock or reduce the power consumption of the CPU. The core does not allow FCLK or HCLK to be disabled during a debug session. Since these clocks are required for the debug operation, they must remain active during a debug. MCU integrates a special way to allow users to debug software in low-power modes.

For this purpose, the debugger must first set some debug configuration registers to change the behavior of low-power modes:

• In Sleep mode, the DBG\_SLEEP bit of the MCUDBG\_CTRL register must be previously set by the debugger. This will feed HCLK with the same clock provided for FCLK (system clock previously configured by the software).

• In Stop mode, the DBG\_STOP bit must be previously set by the debugger. This will enable the internal RC oscillator clock to feed FCLK and HCLK in Stop mode.

# 20.2.2 Debug Support for Timer, Watchdog, bxCAN, and I<sup>2</sup>C

During a breakpoint, it is necessary to select the operation mode for counters according to the different usages of timers and watchdogs:

- During a breakpoint, counters continue to count. This is usually required when an output PWM is controlling a motor.
- During a breakpoint, counters stop counting. This is required for the counters of watchdogs.

For bxCAN, users can choose to block the update of the receive register during a breakpoint. For I<sup>2</sup>C, users can choose to block the SMBUS timeout during a breakpoint.

#### 20.2.3 ID Code

There are several ID codes inside the V84XXX microcontroller. It is strongly recommended that tool designers use the MCUDEVICEID mapped in the external PPB memory at address 0xE0042000 to lock



their debuggers. This ID identifies MCU's part number. It is part of the MCUDBG component and is mapped on the external PPB bus.

This code is accessible by using the JTAG debug port (4  $\sim$  5 pins), or the SW debug port (2 pins), or by the user software. It is even accessible while MCU is under system reset.

Only the DEV\_ID[11:0] should be used for identification by the debugger/programmer tools.

#### 20.2.4 SWJ Debug Port Pins

Five general-purpose I/O ports of V84XXX can be used as SWJ-DP port pins. These pins are available on all packages. After reset (SYSRESETn or PORESETn), all five pins used for the SWJ- DP are immediately initialized and assigned as dedicated pins for the debugger.

V84XXX microcontroller implements the AF remap and debug I/O configuration register (AFIO\_MAPR) (Please refer to <u>Section 7.5.11</u>) or AF remap and debug I/O configuration register 7(AFIO\_MAPR7) (Please refer to <u>Section 7.5.21</u>) to disable some parts of the SWJ-DP port or all functions of the pins; these dedicated pins are released for general-purpose I/O usages.Register programming is done by the user software program instead of the debugger host. Please refer to <u>Section 7.4.3</u>.

#### 20.2.5 Internal pull-up and pull-down on JTAG pins

It is necessary to ensure connected to flip-flops to control the debug mode features. Special care must be taken with the SWCLK/TCK pin which is directly connected to the clock of some of these flip-flops.

To avoid any uncontrolled IO levels, the device embeds internal pull-ups and pull-downs on the JTAG input pins:

- JNTRST: Internal pull-up
- JTDI: Internal pull-up
- JTMS/SWDIO: Internal pull-up
- JTCK/SWCLK: Internal pull-down

Once a JTAG IO is released by the user software, the GPIO controller takes control again. The reset states of the GPIO control registers put the I/Os in the equivalent state:

• JNTRST: Input pull-up



- JTDI: Input pull-up
- JTMS/SWDIO: Input pull-up
- JTCK/SWCLK: Input pull-down
- JTDO: AF output floatingInput floating

The software can then use these I/Os as standard GPIOs.

# 20.3 MCUDBG Registers

## 20.3.1 MCUDBG Control Register (MCUDBG\_CTRL)

The MCUDBG\_CTRL register is mapped on the external PPB bus at base address, 0xE0042000. It is asynchronously reset by PORESET (and not by system reset). It can be written by the debugger when the core is at reset state.

Address: 0xE0042004 (Accessible only for 32-bit accesses)

| Bit                    | Name                   | Туре | Description                                                                                                                                                                                                                                                                                                                                                   |
|------------------------|------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31                 | DBG_I2C3_SMBUS_TIMEOUT | rw   | <ul><li>Stop SMBUS timeout mode when the core is</li><li>stopped.</li><li>0: Same as normal mode operation;</li><li>1: Freeze the timeout control of SMBUS.</li></ul>                                                                                                                                                                                         |
| Bit 24:21              | -                      | -    | Reserved. Must be kept as 0.                                                                                                                                                                                                                                                                                                                                  |
| Bit 30:25<br>Bit 20:17 | DBG_TMRx_STOP          | rw   | Timer counter stops when the core is halted. (x = 145)<br>0: The clock of the involved timer counter is fed<br>even if the core is halted, and the outputs behave<br>normally.<br>1: The clock of the involved timer counter stops<br>when the core is halted, and the outputs are<br>disabled (just like an emergency stop in response<br>to a break event). |

POR reset: 0x00000000 (Not reset by system reset)



| Bit 16 DBG_I2C2_SMBUS_TIMEOUT |                        |    | SMBUS timeout mode stops when the core is halted.   |
|-------------------------------|------------------------|----|-----------------------------------------------------|
|                               | DBG_I2C2_SMBUS_TIMEOUT | rw |                                                     |
|                               |                        |    | 0: The same behavior as in the normal mode          |
|                               |                        |    | 1: The SMBUS timeout is frozen.                     |
|                               |                        | rw | SMBUS timeout mode stops when the core is           |
|                               |                        |    | halted.                                             |
| Bit 15                        | DBG_I2C1_SMBUS_TIMEOUT |    | 0: The same behavior as in the normal mode          |
|                               |                        |    | 1: The SMBUS timeout is frozen.                     |
|                               |                        |    | CAN1 stops when the care enters dehug state         |
| Dit 14                        |                        |    | CAN1 stops when the core enters debug state.        |
| Bit 14                        | DBG_CAN1_STOP          |    | 0: The same behavior as in the normal mode          |
|                               |                        |    | 1: The receive registers of CAN1 are disabled.      |
|                               |                        |    | Counter stops when the core enters debug state. (x  |
|                               | DBG_TMRx_STOP          |    | = 41)                                               |
| Bit 13:10                     |                        |    | 0: The counter of the involved timer still works    |
|                               |                        |    | normally.                                           |
|                               |                        |    | 1: The counter of the involved timer stops.         |
|                               |                        |    |                                                     |
|                               |                        |    | Debug window watchdog stops when the core           |
|                               |                        |    | enters debug state.                                 |
| Bit 9 DBG_WWDG_STOP           | DBG_WWDG_STOP          |    | 0: The window watchdog counter still works          |
|                               |                        |    | normally.                                           |
|                               |                        |    | 1: The window watchdog counter stops.               |
| Bit 8 DB0                     | DBG_IWDG_STOP          |    | Watchdog stops when the core enters debug state.    |
|                               |                        |    | 0: The watchdog counter still works normally.       |
|                               |                        |    | 1: The watchdog counter stops.                      |
| Bit 7:3                       | -                      | -  | Reserved. Must be kept as 0.                        |
|                               |                        |    |                                                     |
| Bit 2                         | DBG_STANDBY            | rw | Debug Standby mode                                  |
|                               |                        |    | 0: (FCLK is OFF and HCLK is OFF) The whole digital  |
|                               |                        |    | part is unpowered. From the software point of view, |
|                               |                        |    | exiting the Standby mode is the same as reset       |



|                |           | 1                                                      |                                                        |
|----------------|-----------|--------------------------------------------------------|--------------------------------------------------------|
|                |           |                                                        | (except for a few status bits, which indicate that     |
|                |           |                                                        | MCU just exits from Standby mode).                     |
|                |           |                                                        | 1: (FCLK is ON and HCLK is ON) In this case, the       |
|                |           |                                                        | digital part is not unpowered, and FCLK and HCLK       |
|                |           |                                                        | are clocked by the internal RLD oscillator. In         |
|                |           |                                                        | addition, MCU generates a system reset to exit         |
|                |           |                                                        | Standby mode, which is the same as reset.              |
|                |           |                                                        | Debug Stop mode                                        |
|                |           |                                                        | 0: (FCLK is OFF and HCLK is OFF) In Stop mode, the     |
|                |           |                                                        | clock controller disables all clocks (including HCLK   |
|                |           |                                                        | and FCLK). When exiting the STOP mode, the clock       |
| Bit 1 DBG_STOP |           |                                                        | configuration is identical to the one after reset (MCU |
|                |           | is clocked by the 8 MHz internal RC oscillator (HSI)). |                                                        |
|                |           | Consequently, the software must reprogram the clock    |                                                        |
|                | rw        | controller to enable PLL, Xtal, etc.                   |                                                        |
|                |           | 1: (FCLK is ON and HCLK is ON) In Stop mode, FCLK      |                                                        |
|                |           | and HCLK are clocked by the internal RC oscillator.    |                                                        |
|                |           |                                                        | When exiting the Stop mode, the software must          |
|                |           |                                                        | reprogram the clock controller to enable PLL, Xtal,    |
|                |           |                                                        | etc. (in the same way to configure this bit when it is |
|                |           |                                                        | 0).                                                    |
|                |           |                                                        | Debug Sleep mode                                       |
|                |           |                                                        | 0: (FCLK is ON and HCLK is OFF) In Sleep mode,         |
|                |           |                                                        | FCLK is clocked by the system clock as previously      |
|                |           |                                                        | configured, while HCLK is disabled. In this case, the  |
| Bit 0 DBG_SLEE |           |                                                        | clock controller configuration is not reset;           |
|                | DBG_SLEEP | rw                                                     | consequently, when exiting the Sleep mode, the         |
|                |           |                                                        | software does not need to reconfigure the clock        |
|                |           |                                                        | controller.                                            |
|                |           |                                                        | 1: (FCLK is ON and HCLK is ON) In Sleep mode,          |
|                |           |                                                        | FCLK and HCLK are clocked by the system clock as       |
|                |           |                                                        | previously configured by the software.                 |
| Allin          | 1         | L                                                      | 1]                                                     |



