

N32G003 series

# 32-bit ARM® Cortex®-M0 microcontroller

User manual V1.0



## Contents

| 1 Abbrevia | ations in the text                          |  |
|------------|---------------------------------------------|--|
| 1.1 List   | of abbreviations for registers              |  |
| 1.2 Avail  | lable peripherals                           |  |
| 2 Memory   | and bus architecture                        |  |
| 2.1 Syste  | em architecture                             |  |
| 2.1.1      | Bus architecture                            |  |
| 2.1.2      | Bus address mapping                         |  |
| 2.1.3      | Boot management                             |  |
| 2.2 Men    | ory system                                  |  |
| 2.2.1      | FLASH specification                         |  |
| 2.2.2      | SRAM                                        |  |
| 2.2.3      | FLASH register description                  |  |
| 3 Power co | ontrol (PWR)                                |  |
| 3.1 Gene   | eral description                            |  |
| 3.1.1      | Power supply                                |  |
| 3.1.2      | Power supply supervisor                     |  |
| 3.2 Powe   | er modes                                    |  |
| 3.2.1      | STOP mode                                   |  |
| 3.2.2      | PD mode                                     |  |
| 3.3 Debu   | ıg mode                                     |  |
| 3.3.1      | Low power mode debug mode support           |  |
| 3.3.2      | Peripheral debug support                    |  |
| 3.4 PWF    | R registers                                 |  |
| 3.4.1      | PWR register overview                       |  |
| 3.4.2      | Power control register (PWR_CTRL)           |  |
| 3.4.3      | Power control status register (PWR_CTRLSTS) |  |
| 3.4.4      | Power control register 2 (PWR_CTRL2)        |  |
| 3.4.5      | Power control register 3 (PWR_CTRL3)        |  |
| 3.4.6      | Power control register 4 (PWR_CTRL4)        |  |
| 3.4.7      | Power control register 5 (PWR_CTRL5)        |  |
| 3.4.8      | Power control register 6 (PWR_CTRL6)        |  |
| 3.4.9      | Debug control register (DBG_CTRL)           |  |
| 4 Reset an | d clock control (RCC)                       |  |
| 4.1 Rese   | t Control Unit                              |  |
| 4.1.1      | Power reset                                 |  |
| 4.1.2      | System reset                                |  |
| 4.2 Cloc   | k control unit                              |  |
| 4.2.1      | Clock Tree Diagram                          |  |



| 4.2.2      | HSI clock                                            | 58 |
|------------|------------------------------------------------------|----|
| 4.2.3      | LSI clock                                            | 59 |
| 4.2.4      | System clock (SYSCLK) selection                      | 59 |
| 4.2.5      | Watchdog clock                                       | 59 |
| 4.2.6      | TIM6 clock                                           | 60 |
| 4.2.7      | Clock output(MCO)                                    | 60 |
| 4.3 RCC    | registers                                            | 60 |
| 4.3.1      | RCC register overview                                | 60 |
| 4.3.2      | HSI clock control register (RCC_HSICTRL)             | 61 |
| 4.3.3      | Clock configuration register (RCC_CFG)               | 62 |
| 4.3.4      | Peripheral reset register (RCC_PRST)                 | 63 |
| 4.3.5      | AHB peripheral clock enable register (RCC_AHBPCLKEN) | 65 |
| 4.3.6      | APB peripheral clock enable register (RCC_APBPCLKEN) | 66 |
| 4.3.7      | Low speed clock control register (RCC_LSICTRL)       | 67 |
| 4.3.8      | Control/status register (RCC_CTRLSTS)                | 68 |
| 4.3.9      | Clock configuration register 2 (RCC_CFG2)            |    |
| 4.3.10     | EMC control register (RCC_EMCCTRL)                   | 71 |
| 5 GPIO and | 1 AFIO                                               | 72 |
|            |                                                      |    |
|            | nary                                                 |    |
|            | nction description                                   |    |
| 5.2.1      | IO mode configuration                                |    |
| 5.2.2      | Status after reset                                   |    |
| 5.2.3      | Individual bit setting and bit clearing              |    |
| 5.2.4      | External interrupt/wake-up line                      |    |
| 5.2.5      | Alternate function                                   |    |
| 5.2.6      | I/O configuration of peripherals                     |    |
| 5.2.7      | GPIO locking mechanism                               |    |
| 5.3 GPIO   | registers                                            |    |
| 5.3.1      | GPIOA register overview                              |    |
| 5.3.2      | GPIOB register overview                              |    |
| 5.3.3      | GPIO port mode register (GPIOx_PMODE)                |    |
| 5.3.4      | GPIO port type register (GPIOx_POTYPE)               | 89 |
| 5.3.5      | GPIO slew rate register (GPIOx_SR)                   |    |
| 5.3.6      | GPIO port pull-up/pull-down register (GPIOx_PUPD)    | 90 |
| 5.3.7      | GPIO port input data register (GPIOx_PID)            |    |
| 5.3.8      | GPIO port output data register (GPIOx_POD)           |    |
| 5.3.9      | GPIO port bit set/clear register (GPIOx_PBSC)        |    |
| 5.3.10     | GPIO port bit clear register (GPIOx_PBC)             |    |
| 5.3.11     | GPIO port lock register (GPIOx_PLOCK)                |    |
| 5.3.12     | GPIO alternate function low register (GPIOx_AFL)     |    |
| 5.3.13     | GPIO alternate function high register (GPIOx_AFH)    |    |
| 5.3.14     | GPIO driver strength register (GPIOx_DS)             |    |
| 5.4 AFIO   | registers                                            |    |



| 5.4.1      | AFIO register overview                                 |     |
|------------|--------------------------------------------------------|-----|
| 5.4.2      | AFIO configuration register (AFIO_CFG)                 |     |
| 6 Interrup | ts and events                                          |     |
| 6 1 Neste  | ed vectored interrupt controller                       | 98  |
| 6.1.1      | SysTick calibration value register                     |     |
| 6.1.2      | Interrupt and exception vectors.                       |     |
|            | rnal interrupt/event controller (EXTI)                 |     |
| 6.2.1      | Introduction                                           |     |
| 6.2.2      | Main features                                          |     |
| 6.2.3      | Functional description                                 |     |
| 6.2.4      | EXTI line mapping                                      |     |
| 6.3 EXT    | I Registers                                            |     |
| 6.3.1      | EXTI register overview                                 |     |
| 6.3.2      | Interrupt mask register(EXTI_IMASK)                    |     |
| 6.3.3      | Event mask register(EXTI_EMASK)                        |     |
| 6.3.4      | Rising edge trigger selection register(EXTI_RT_CFG)    |     |
| 6.3.5      | Falling edge trigger selection register(EXTI_FT_CFG)   |     |
| 6.3.6      | Software interrupt enable register(EXTI_SWIE)          |     |
| 6.3.7      | Interrupt request pending register(EXTI_PEND)          |     |
| 7 CRC cale | culation unit                                          |     |
| 7.1 CRC    | introduction                                           |     |
|            | main features                                          |     |
|            | function description                                   |     |
|            | software calculation method                            |     |
| 7.5 CRC    | registers                                              |     |
| 7.5.1      | CRC register overview                                  |     |
| 7.5.2      | CRC16 control register (CRC_CRC16CTRL)                 |     |
| 7.5.3      | CRC16 input data register (CRC_CRC16DAT)               |     |
| 7.5.4      | CRC cyclic redundancy check code register (CRC_CRC16D) |     |
| 7.5.5      | LRC result register (CRC_LRC)                          |     |
| 8 Advance  | d-control timers (TIM1)                                | 110 |
| 8 1 TIM    | l introduction                                         |     |
|            | features of TIM1                                       |     |
|            | function description                                   |     |
| 8.3.1      | Time-base unit                                         |     |
| 8.3.2      | Counter mode                                           |     |
| 8.3.3      | Repetition counter                                     |     |
| 8.3.4      | Clock selection                                        |     |
| 8.3.5      | Capture/compare channels                               |     |
| 8.3.6      | Input capture mode                                     |     |
| 8.3.7      | PWM input mode                                         |     |



| 8.3.8       | Forced output mode                              |     |
|-------------|-------------------------------------------------|-----|
| 8.3.9       | Output compare mode                             |     |
| 8.3.10      | PWM mode                                        |     |
| 8.3.11      | One-pulse mode                                  |     |
| 8.3.12      | Clearing the OCxREF signal on an external event |     |
| 8.3.13      | Complementary outputs with dead-time insertion  |     |
| 8.3.14      | Break function                                  |     |
| 8.3.15      | Debug mode                                      |     |
| 8.3.16      | TIMx and external trigger synchronization       |     |
| 8.3.17      | Timer synchronization                           |     |
| 8.3.18      | 6-step PWM generation                           |     |
| 8.4 TIM     | x register description(x=1)                     |     |
| 8.4.1       | Register Overview                               |     |
| 8.4.2       | Control register 1 (TIMx_CTRL1)                 |     |
| 8.4.3       | Control register 2 (TIMx_CTRL2)                 | 147 |
| 8.4.4       | Slave mode control register (TIMx_SMCTRL)       |     |
| 8.4.5       | Interrupt enable registers (TIMx_DINTEN)        |     |
| 8.4.6       | Status registers (TIMx_STS)                     |     |
| 8.4.7       | Event generation registers (TIMx_EVTGEN)        |     |
| 8.4.8       | Capture/compare mode register 1 (TIMx_CCMOD1)   |     |
| 8.4.9       | Capture/compare mode register 2 (TIMx_CCMOD2)   |     |
| 8.4.10      | Capture/compare enable registers (TIMx_CCEN)    |     |
| 8.4.11      | Counters (TIMx_CNT)                             |     |
| 8.4.12      | Prescaler (TIMx_PSC)                            |     |
| 8.4.13      | Auto-reload register (TIMx_AR)                  |     |
| 8.4.14      | Repeat count registers (TIMx_REPCNT)            |     |
| 8.4.15      | Capture/compare register 1 (TIMx_CCDAT1)        |     |
| 8.4.16      | Capture/compare register 2 (TIMx_CCDAT2)        |     |
| 8.4.17      | Capture/compare register 3 (TIMx_CCDAT3)        |     |
| 8.4.18      | Capture/compare register 4 (TIMx_CCDAT4)        |     |
| 8.4.19      | Break and Dead-time registers (TIMx_BKDT)       |     |
| 8.4.20      | Capture/compare mode registers 3(TIMx_CCMOD3)   |     |
| 8.4.21      | Capture/compare register 5 (TIMx_CCDAT5)        |     |
| 9 General-j | purpose timers (TIM3)                           |     |
| 9.1 Gene    | ral-purpose timers introduction                 |     |
| 9.2 Main    | features of General-purpose timers              |     |
| 9.3 Gene    | ral-purpose timer description                   |     |
| 9.3.1       | Time-base unit                                  |     |
| 9.3.2       | Counter mode                                    |     |
| 9.3.3       | Clock selection                                 | 176 |
| 9.3.4       | Capture/compare channels                        |     |
| 9.3.5       | Input capture mode                              |     |
| 9.3.6       | PWM input mode                                  |     |



| 9.3.7                                                                                                                                                                                            | Forced output mode                                                                                                                                                                                       |                                                                                                                                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9.3.8                                                                                                                                                                                            | Output compare mode                                                                                                                                                                                      |                                                                                                                                                                                                                 |
| 9.3.9                                                                                                                                                                                            | PWM mode                                                                                                                                                                                                 |                                                                                                                                                                                                                 |
| 9.3.10                                                                                                                                                                                           | One-pulse mode                                                                                                                                                                                           |                                                                                                                                                                                                                 |
| 9.3.11                                                                                                                                                                                           | Clearing the OCxREF signal on an external event                                                                                                                                                          |                                                                                                                                                                                                                 |
| 9.3.12                                                                                                                                                                                           | Debug mode                                                                                                                                                                                               |                                                                                                                                                                                                                 |
| 9.3.13                                                                                                                                                                                           | TIMx and external trigger synchronization                                                                                                                                                                |                                                                                                                                                                                                                 |
| 9.3.14                                                                                                                                                                                           | Timer synchronization                                                                                                                                                                                    |                                                                                                                                                                                                                 |
| 9.4 TIMx                                                                                                                                                                                         | register description(x=3)                                                                                                                                                                                |                                                                                                                                                                                                                 |
| 9.4.1                                                                                                                                                                                            | Register Overview                                                                                                                                                                                        |                                                                                                                                                                                                                 |
| 9.4.2                                                                                                                                                                                            | Control register 1 (TIMx_CTRL1)                                                                                                                                                                          |                                                                                                                                                                                                                 |
| 9.4.3                                                                                                                                                                                            | Control register 2 (TIMx_CTRL2)                                                                                                                                                                          |                                                                                                                                                                                                                 |
| 9.4.4                                                                                                                                                                                            | Slave mode control register (TIMx_SMCTRL)                                                                                                                                                                |                                                                                                                                                                                                                 |
| 9.4.5                                                                                                                                                                                            | Interrupt enable registers (TIMx_DINTEN)                                                                                                                                                                 |                                                                                                                                                                                                                 |
| 9.4.6                                                                                                                                                                                            | Status registers (TIMx_STS)                                                                                                                                                                              |                                                                                                                                                                                                                 |
| 9.4.7                                                                                                                                                                                            | Event generation registers (TIMx_EVTGEN)                                                                                                                                                                 |                                                                                                                                                                                                                 |
| 9.4.8                                                                                                                                                                                            | Capture/compare mode register 1 (TIMx_CCMOD1)                                                                                                                                                            |                                                                                                                                                                                                                 |
| 9.4.9                                                                                                                                                                                            | Capture/compare enable registers (TIMx_CCEN)                                                                                                                                                             |                                                                                                                                                                                                                 |
| 9.4.10                                                                                                                                                                                           | Counters (TIMx_CNT)                                                                                                                                                                                      |                                                                                                                                                                                                                 |
| 9.4.11                                                                                                                                                                                           | Prescaler (TIMx_PSC)                                                                                                                                                                                     |                                                                                                                                                                                                                 |
| 9.4.12                                                                                                                                                                                           | Auto-reload register (TIMx_AR)                                                                                                                                                                           |                                                                                                                                                                                                                 |
| 9.4.13                                                                                                                                                                                           | Capture/compare register 1 (TIMx_CCDAT1)                                                                                                                                                                 |                                                                                                                                                                                                                 |
| 9.4.14                                                                                                                                                                                           | Capture/compare register 2 (TIMx_CCDAT2)                                                                                                                                                                 | 211                                                                                                                                                                                                             |
| 9.4.14                                                                                                                                                                                           | Capture/compare register 2 (TIWA_CCDAT2)                                                                                                                                                                 |                                                                                                                                                                                                                 |
|                                                                                                                                                                                                  |                                                                                                                                                                                                          |                                                                                                                                                                                                                 |
| 10 Basic tim                                                                                                                                                                                     | ners (TIM6)                                                                                                                                                                                              |                                                                                                                                                                                                                 |
| <b>10 Basic tim</b><br>10.1 Basic                                                                                                                                                                | e timers introduction                                                                                                                                                                                    |                                                                                                                                                                                                                 |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main                                                                                                                                                   | timers (TIM6)                                                                                                                                                                                            | <b></b>                                                                                                                                                                                                         |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic                                                                                                                                     | e timers introduction                                                                                                                                                                                    | <b>211</b><br>211<br>211<br>211<br>212                                                                                                                                                                          |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1                                                                                                                           | e timers introduction<br>features of Basic timers<br>c timers description<br>Time-base unit                                                                                                              | <b>211</b><br>211<br>211<br>211<br>212<br>212<br>212                                                                                                                                                            |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2                                                                                                                 | e timers introduction                                                                                                                                                                                    | <b>211</b> 211 211 211 212 212 212 213                                                                                                                                                                          |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3                                                                                                       | hers (TIM6)<br>timers introduction                                                                                                                                                                       | <b>211</b> 211 211 211 212 212 212 213 216                                                                                                                                                                      |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4                                                                                             | e timers introduction                                                                                                                                                                                    | <b>211</b> 211 211 211 212 212 213 216 216                                                                                                                                                                      |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4<br>10.4 TIM <sub>2</sub>                                                                    | hers (TIM6)<br>te timers introduction<br>a features of Basic timers<br>te timers description<br>Time-base unit<br>Counter mode<br>Clock selection<br>Debug mode<br>x register(x=6)                       | <b>211</b> 211 211 211 212 212 212 213 216 216 216 216                                                                                                                                                          |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4<br>10.4 TIM <sub>2</sub><br>10.4.1                                                          | hers (TIM6)<br>te timers introduction<br>a features of Basic timers<br>te timers description<br>Time-base unit<br>Counter mode<br>Clock selection<br>Debug mode<br>k register (x=6)<br>Register overview | <b>211</b> 211 211 211 212 212 212 213 216 216 216 216 217                                                                                                                                                      |
| 10 Basic tim<br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4<br>10.4 TIM5<br>10.4.1<br>10.4.2                                                                   | hers (TIM6)<br>timers introduction                                                                                                                                                                       | <b>211</b> 211 211 211 212 212 212 213 216 216 216 216 217 217                                                                                                                                                  |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4<br>10.4 TIM<br>10.4.1<br>10.4.2<br>10.4.3                                                   | hers (TIM6)<br>c timers introduction                                                                                                                                                                     | <b>211</b> 211 211 211 212 212 212 213 216 216 216 216 217 217 218                                                                                                                                              |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4<br>10.4 TIM2<br>10.4.1<br>10.4.2<br>10.4.3<br>10.4.4                                        | hers (TIM6)<br>timers introduction                                                                                                                                                                       | <b>211</b> 211 211 211 212 212 212 213 216 216 216 216 217 217 218 219                                                                                                                                          |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4<br>10.4 TIM<br>10.4.1<br>10.4.2<br>10.4.3<br>10.4.4<br>10.4.5                               | arers (TIM6)                                                                                                                                                                                             | 211         211         211         211         211         212         212         212         213         216         216         217         217         218         219                                     |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4<br>10.4 TIM2<br>10.4.1<br>10.4.2<br>10.4.3<br>10.4.4<br>10.4.5<br>10.4.6                    | hers (TIM6)<br>te timers introduction                                                                                                                                                                    | 211         211         211         211         211         211         212         212         213         216         216         217         217         217         217         218         219         219 |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4<br>10.4 TIM5<br>10.4.1<br>10.4.2<br>10.4.3<br>10.4.4<br>10.4.5<br>10.4.6<br>10.4.7          | e timers introduction<br>features of Basic timers                                                                                                                                                        | 211         211         211         211         211         211         212         212         213         216         216         217         218         219         219         210         211             |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4<br>10.4 TIM<br>10.4.1<br>10.4.2<br>10.4.3<br>10.4.4<br>10.4.5<br>10.4.6<br>10.4.7<br>10.4.8 | e timers introduction<br>te timers description                                                                                                                                                           | 211         211         211         211         211         212         212         212         213         216         216         217         218         219         219         219         220             |
| <b>10 Basic tim</b><br>10.1 Basic<br>10.2 Main<br>10.3 Basic<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4<br>10.4 TIM<br>10.4.1<br>10.4.2<br>10.4.3<br>10.4.4<br>10.4.5<br>10.4.6<br>10.4.7<br>10.4.8 | e timers introduction<br>a features of Basic timers                                                                                                                                                      | 211         211         211         211         211         212         212         212         213         216         216         217         218         219         219         219         220             |



| 11.2 IWD0    | G main features                                    |  |
|--------------|----------------------------------------------------|--|
| 11.3 IWD0    | G function description                             |  |
| 11.3.1       | Register access protection                         |  |
| 11.3.2       | Debug mode                                         |  |
| 11.3.3       | Low power consumption                              |  |
| 11.4 User 1  | Interface                                          |  |
| 11.4.1       | Operate Flow                                       |  |
| 11.4.2       | IWDG configuration flow                            |  |
| 11.5 IWD0    | G registers                                        |  |
| 11.5.1       | IWDG register map                                  |  |
| 11.5.2       | IWDG Key register (IWDG_KEY)                       |  |
| 11.5.3       | IWDG Pre-Scaler register (IWDG_PREDIV)             |  |
| 11.5.4       | IWDG Reload register (IWDG_RELV)                   |  |
| 11.5.5       | IWDG Status register (IWDG_STS)                    |  |
| 11.5.6       | IWDG Freeze register (IWDG_FREEZE)                 |  |
| 12 Analog to | digital conversion (ADC)                           |  |
| 12.1 ADC     | introduction                                       |  |
|              | Features                                           |  |
|              | function description                               |  |
| 12.3.1       | ADC clock                                          |  |
| 12.3.2       | ADC switch control                                 |  |
| 12.3.3       | Channel selection                                  |  |
| 12.3.4       | Internal channel                                   |  |
| 12.3.5       | Single conversion mode                             |  |
| 12.3.6       | Continuous conversion mode                         |  |
| 12.3.7       | Timing diagram                                     |  |
| 12.3.8       | Analog watchdog                                    |  |
| 12.3.9       | Scan mode                                          |  |
| 12.4 Data a  | aligned                                            |  |
|              | ammable channel sampling time                      |  |
| -            | nally triggered conversion                         |  |
|              | interrupt                                          |  |
| 12.8 ADC     | registers                                          |  |
| 12.8.1       | ADC registers                                      |  |
| 12.8.2       | ADC status register (ADC_STS)                      |  |
| 12.8.3       | ADC control register 1 (ADC_CTRL1)                 |  |
| 12.8.4       | ADC control register 2 (ADC_CTRL2)                 |  |
| 12.8.5       | ADC control register 3 (ADC_CTRL3)                 |  |
| 12.8.6       | ADC sampling time register (ADC_ SAMPT)            |  |
| 12.8.7       | ADC watchdog high threshold register (ADC_WDGHIGH) |  |
| 12.8.8       | ADC watchdog low threshold register (ADC_WDGLOW)   |  |
| 12.8.9       | ADC regular data register x (ADC_DATx) (x= 04)     |  |
|              |                                                    |  |



| 3 Compara    | tor (COMP)                                     |  |
|--------------|------------------------------------------------|--|
| 13.1 COM     | P system connection block diagram              |  |
| 13.2 COM     | P features                                     |  |
| 13.3 COM     | P configuration process                        |  |
| 13.4 COM     | P working mode                                 |  |
| 13.4.1       | Independent comparator                         |  |
| 13.5 Comp    | parator interconnection                        |  |
| -            | upt                                            |  |
|              | P registers                                    |  |
| 13.7.1       | COMP registers                                 |  |
| 13.7.2       | COMP interrupt enable register (COMP_INTEN)    |  |
| 13.7.3       | COMP interrupt status register (COMP_INTSTS)   |  |
| 13.7.4       | COMP lock register (COMP_LOCK)                 |  |
| 13.7.5       | COMP control register (COMP_CTRL)              |  |
| 13.7.6       | COMP filter control register (COMP_FILC)       |  |
| 13.7.7       | COMP filter clock register (COMP_FILP)         |  |
| 4 Inter-inte | grated circuit bus(I <sup>2</sup> C)           |  |
| 14.1 Introd  | luction                                        |  |
| 14.2 Main    | features                                       |  |
| 14.3 Funct   | ion description                                |  |
| 14.3.1       | SDA and SCL line control                       |  |
| 14.3.2       | Software communication process                 |  |
| 14.3.3       | Error conditions description                   |  |
| 14.3.4       | Packet error check                             |  |
| 14.3.5       | Noise filter                                   |  |
| 14.4 Interr  | upt request                                    |  |
| 14.5 I2C re  | egisters                                       |  |
| 14.5.1       | I2C register overview                          |  |
| 14.5.2       | I2C Control register 1 (I2C_CTRL1)             |  |
| 14.5.3       | I2C Control register 2 (I2C_CTRL2)             |  |
| 14.5.4       | I2C Own address register 1 (I2C_OADDR1)        |  |
| 14.5.5       | I2C Own address register 2 (I2C_OADDR2)        |  |
| 14.5.6       | I2C Data register (I2C_DAT)                    |  |
| 14.5.7       | I2C Status register 1 (I2C_STS1)               |  |
| 14.5.8       | I2C Status register 2 (I2C_STS2)               |  |
| 14.5.9       | I2C Clock control register (I2C_CLKCTRL)       |  |
| 14.5.10      | I2C Rise time register (I2C_TMRISE)            |  |
| 14.5.11      | I2C Filter control register (I2C_GFLTRCTRL)    |  |
| 14.5.12      | I2C master receive byte register (I2C_BYTENUM) |  |
|              | asynchronous receiver transmitter (UART)       |  |
|              | luction                                        |  |
|              |                                                |  |



| 15.2 Main     | features                                          |  |
|---------------|---------------------------------------------------|--|
| 15.3 Funct    | tional block diagram                              |  |
| 15.4 Funct    | tion description                                  |  |
| 15.4.1        | UART frame format                                 |  |
| 15.4.2        | Transmitter                                       |  |
| 15.4.3        | Receiver                                          |  |
| 15.4.4        | Generation of fractional baud rate                |  |
| 15.4.5        | Receiver's tolerance clock deviation              |  |
| 15.4.6        | Parity control                                    |  |
| 15.4.7        | Multiprocessor communication                      |  |
| 15.4.8        | Single-line half-duplex communication             |  |
| 15.5 Interr   | rupt request                                      |  |
| 15.6 UAR      | T mode configuration                              |  |
| 15.7 UAR      | T registers                                       |  |
| 15.7.1        | UART register map                                 |  |
| 15.7.2        | UART status register (UART_STS)                   |  |
| 15.7.3        | UART data register (UART_DAT)                     |  |
| 15.7.4        | UART baud rate configuration register (UART_BRCF) |  |
| 15.7.5        | UART control register 1(UART_CTRL1)               |  |
| 15.7.6        | UART control register 2(UART_CTRL2)               |  |
| 15.7.7        | UART control register 3(UART_CTRL3)               |  |
| 16 Serial per | ripheral interface (SPI)                          |  |
| 16.1 SPI ii   | ntroduction                                       |  |
|               | nain features                                     |  |
|               | unction description                               |  |
| 16.3.1        | General description                               |  |
| 16.3.2        | SPI work mode                                     |  |
| 16.3.3        | Status flag                                       |  |
| 16.3.4        | Turn off the SPI                                  |  |
| 16.3.5        | Error flag                                        |  |
| 16.3.6        | SPI interrupt                                     |  |
| 16.4 SPI r    | egister                                           |  |
| 16.4.1        | SPI register overview                             |  |
| 16.4.2        | SPI control register 1 (SPI_CTRL1)                |  |
| 16.4.3        | SPI control register 2 (SPI_CTRL2)                |  |
| 16.4.4        | SPI status register (SPI_STS)                     |  |
| 16.4.5        | SPI data register (SPI_DAT)                       |  |
| 17 Beener     |                                                   |  |
| -             |                                                   |  |
|               | duction                                           |  |
|               | tion description                                  |  |
| -             | er registers                                      |  |
| 17.3.1        | Beeper register overview                          |  |

# Nation 😵

| 17.3.2 Beeper control register (BEEPER_CTRL) |  |
|----------------------------------------------|--|
| 18 Debug support (DBG)                       |  |
| 18.1 Overview                                |  |
| 18.2 SWD function                            |  |
| 18.2.1 Pin assignment                        |  |
| 19 Unique device serial number (UID)         |  |
| 19.1 Introduction                            |  |
| 19.2 UID register                            |  |
| 19.3 UCID register                           |  |
| 19.4 DBGMCU_ID register                      |  |
| 20 Version history                           |  |
| 21 Notice                                    |  |



## List of Table

| Table 2-1 List of peripheral register addresses             | 21 |
|-------------------------------------------------------------|----|
| Table 2-2 Flash bus address list                            | 23 |
| Table 2-3 Option byte list                                  | 27 |
| Table 2-4 Read protection configuration list                | 28 |
| Table 2-5 Flash read-write-erase permission control table   | 29 |
| Table 2-6 FLASH register overview                           | 31 |
| Table 3-1 Power modes                                       | 42 |
| Table 3-2 Peripheral running status                         | 43 |
| Table 3-3 PWR register overview                             | 45 |
| Table 4-1 RCC register overview                             | 60 |
| Table 5-1 Relationship between I/O modes and configurations | 73 |
| Table 5-2 I/O List of functional features of the lipin      | 74 |
| Table 5-3 Correspondence between EXTI Line and Pin          | 78 |
| Table 5-4 I/O List of functional features of the pin        | 79 |
| Table 5-5 TIM1 alternate function I/O remapping             | 79 |
| Table 5-6 TIM3 alternate function I/O remapping             | 80 |
| Table 5-7 UART1 alternate function I/O remapping            | 81 |
| Table 5-8 UART2 alternate function I/O remapping            | 81 |
| Table 5-9 I2C alternate function I/O remapping              | 82 |
| Table 5-10 SPI alternate function I/O remapping             | 82 |
| Table 5-11 COMP alternate function I/O remapping            | 82 |
| Table 5-12 BEEPER alternate function I/O remapping          | 82 |
| Table 5-13 EVENTOUT alternate function I/O remapping        | 82 |
| Table 5-14 MCO alternate function I/O remapping             | 83 |
| Table 5-15 ADC                                              | 83 |
| Table 5-16 TIM1                                             | 83 |
| Table 5-17 TIM3                                             | 83 |
| Table 5-18 UART                                             | 83 |
| Table 5-19 I2C                                              | 83 |
| Table 5-20 SPI                                              | 83 |



| Table 5-21 COMP                                                                          |     |
|------------------------------------------------------------------------------------------|-----|
| Table 5-22 BEEPER                                                                        |     |
| Table 5-23 Other                                                                         |     |
| Table 5-24 GPIOA register overview                                                       | 85  |
| Table 5-25 GPIOB register overview                                                       |     |
| Table 5-26 AFIO register overview                                                        |     |
| Table 6-1 Vector table                                                                   |     |
| Table 6-2 EXTI register overview                                                         | 102 |
| Table 7-1 CRC register overview                                                          | 107 |
| Table 8-1 Register overview                                                              | 143 |
| Table 8-2 TIMx internal trigger connection                                               | 150 |
| Table 8-3 Output control bits of complementary OCx and OCxN channels with break function | 161 |
| Table 9-1 Register overview                                                              | 196 |
| Table 9-2 TIMx internal trigger connection                                               | 202 |
| Table 9-3 Output control bits of standard OCx channel                                    | 209 |
| Table 10-1 Register overview                                                             | 217 |
| Table 11-1 IWDG overtime time at 32kHz                                                   | 224 |
| Table 11-2 IWDG register map and reset values                                            | 224 |
| Table 12-1 ADC pins                                                                      | 229 |
| Table 12-2 Analog watchdog channel selection                                             | 232 |
| Table 12-3 Right-align data                                                              | 233 |
| Table 12-4 Left-align data                                                               | 233 |
| Table 12-5 ADC is used for external triggering of regular channels                       | 233 |
| Table 12-6 ADC interrupt                                                                 | 234 |
| Table 12-7 Register overview                                                             |     |
| Table 13-1 Register overview                                                             | 244 |
| Table 14-1 I <sup>2</sup> C interrupt request                                            | 261 |
| Table 14-2 I2C register overview                                                         | 262 |
| Table 15-1 Stop bit configuration                                                        | 277 |
| Table 15-2 Data sampling for noise detection                                             | 281 |
| Table 15-3 Error calculation when setting baud rate                                      |     |



| Table 15-4 When DIV_Decimal = 0. Tolerance of UART receiver  | . 283 |
|--------------------------------------------------------------|-------|
| Table 15-5 When DIV_Decimal != 0. Tolerance of UART receiver | . 283 |
| Table 15-6 Frame format                                      | . 283 |
| Table 15-7 UART interrupt request                            | . 286 |
| Table 15-8 UART mode setting <sup>(1)</sup>                  | . 286 |
| Table 15-9 UART register map and reset values                | . 287 |
| Table 16-1 SPI interrupt request                             | . 307 |
| Table 16-2 SPI register overview                             | . 307 |
| Table 17-1 Beeper register overview                          | . 312 |
| Table 19-1 DBGMCU_ID bit description                         | . 316 |



## List of Figure

| Figure 2-1 Bus architecture                                                                             |
|---------------------------------------------------------------------------------------------------------|
| Figure 2-2 Bus address map                                                                              |
| Figure 3-1 Power supply diagram                                                                         |
| Figure 3-2 Power on reset (POR) / power down reset (PDR) waveform                                       |
| Figure 3-3 PVD threshold diagram                                                                        |
| Figure 3-4 LVR threshold diagram                                                                        |
| Figure 4-1 System reset generation                                                                      |
| Figure 4-2 Clock Tree                                                                                   |
| Figure 5-1 Basic structure of an I/O port                                                               |
| Figure 5-2 Input mode                                                                                   |
| Figure 5-3 Output mode                                                                                  |
| Figure 5-4 Alternate function mode                                                                      |
| Figure 5-5 Analog mode configuration with high impedance                                                |
| Figure 6-1 Extenal interrupt/event controller block diagram                                             |
| Figure 7-1 CRC calculation unit block diagram                                                           |
| Figure 8-1 Block diagram of TIM1111                                                                     |
| Figure 8-2 Counter timing diagram with prescaler division change from 1 to 4112                         |
| Figure 8-3 Timing diagram of up-counting. The internal clock divider factor = 2/N113                    |
| Figure 8-4 Timing diagram of the up-counting, update event when ARPEN=0/1114                            |
| Figure 8-5 Timing diagram of the down-counting, internal clock divided factor = 2/N115                  |
| Figure 8-6 Timing diagram of the Center-aligned, internal clock divided factor =2/N116                  |
| Figure 8-7 A center-aligned sequence diagram that includes counter overflows and underflows (ARPEN = 1) |
| Figure 8-8 Repeat count sequence diagram in down-counting mode                                          |
| Figure 8-9 Repeat count sequence diagram in up-counting mode119                                         |
| Figure 8-10 Repeat count sequence diagram in center-aligned mode                                        |
| Figure 8-11 Control circuit in normal mode, internal clock divided by 1                                 |
| Figure 8-12 TI2 external clock connection example                                                       |
| Figure 8-13 Control circuit in external clock mode 1 122                                                |
| Figure 8-14 External trigger input block diagram                                                        |



| Figure 8-15 Control circuit in external clock mode 2                                               | . 123 |
|----------------------------------------------------------------------------------------------------|-------|
| Figure 8-16 Capture/compare channel (example: channel 1 input stage)                               | . 124 |
| Figure 8-17 Capture/compare channel 1 main circuit                                                 | . 125 |
| Figure 8-18 Output part of channelx (x= 1,2,3, take channel 1 as example)                          | . 126 |
| Figure 8-19 Output part of channelx (x= 4)                                                         | . 126 |
| Figure 8-20 PWM input mode timing                                                                  | . 128 |
| Figure 8-21 Output compare mode, toggle on OC1                                                     | . 130 |
| Figure 8-22 Center-aligned PWM waveform (AR=8)                                                     | . 131 |
| Figure 8-23 Edge-aligned PWM waveform (APR=8)                                                      | . 132 |
| Figure 8-24 Example of One-pulse mode                                                              | . 133 |
| Figure 8-25 Clearing the OCxREF of TIMx                                                            | . 135 |
| Figure 8-26 Complementary output with dead-time insertion                                          | . 136 |
| Figure 8-27 Output behavior in response to a break                                                 | . 138 |
| Figure 8-28 Control circuit in reset mode                                                          | . 139 |
| Figure 8-29 Control circuit in Trigger mode                                                        | . 140 |
| Figure 8-30 Control circuit in Gated mode                                                          | . 141 |
| Figure 8-31 Control circuit in Trigger Mode + External Clock Mode2                                 | . 142 |
| Figure 8-32 6-step PWM generation, COM example (OSSR=1)                                            | . 143 |
| Figure 9-1 Block diagram of TIMx (x=3)                                                             | . 170 |
| Figure 9-2 Counter timing diagram with prescaler division change from 1 to 4                       | . 171 |
| Figure 9-3 Timing diagram of up-counting. The internal clock divider factor = 2/N                  | . 172 |
| Figure 9-4 Timing diagram of the up-counting, update event when ARPEN=0/1                          | . 173 |
| Figure 9-5 Timing diagram of the down-counting, internal clock divided factor = 2/N                | . 174 |
| Figure 9-6 Timing diagram of the Center-aligned, internal clock divided factor =2/N                | . 175 |
| Figure 9-7 A center-aligned sequence diagram that includes counter overflows and underflows (ARPEN | = 1)  |
|                                                                                                    | . 176 |
| Figure 9-8 Control circuit in normal mode, internal clock divided by 1                             | . 177 |
| Figure 9-9 TI2 external clock connection example                                                   | . 178 |
| Figure 9-10 Control circuit in external clock mode 1                                               | . 179 |
| Figure 9-11 External trigger input block diagram                                                   | . 179 |
| Figure 9-12 Control circuit in external clock mode 2                                               | . 180 |
| Figure 9-13 Capture/compare channel (example: channel 1 input stage)                               | . 181 |



| Figure 9-14 Capture/compare channel 1 main circuit                                 | . 182 |
|------------------------------------------------------------------------------------|-------|
| Figure 9-15 Output part of channels $(x = 1,2;take channel 1 as an example)$       | . 183 |
| Figure 9-16 PWM input mode timing                                                  | . 185 |
| Figure 9-17 Output compare mode, toggle on OC1                                     | . 186 |
| Figure 9-18 Center-aligned PWM waveform (AR=8)                                     | . 188 |
| Figure 9-19 Edge-aligned PWM waveform (APR=8)                                      | . 189 |
| Figure 9-20 Example of One-pulse mode                                              | . 190 |
| Figure 9-21 Control circuit in reset mode                                          | . 191 |
| Figure 9-22 Block diagram of timer interconnection                                 | . 192 |
| Figure 9-23 TIM3 gated by OC1REF of TIM1                                           | . 193 |
| Figure 9-24 TIM3 gated by enable signal of TIM1                                    | . 194 |
| Figure 9-25 Trigger TIM3 with an update of TIM1                                    | . 195 |
| Figure 9-26 Triggers timers 1 and 3 using the TI1 input of TIM1                    | . 196 |
| Figure 10-1 Block diagram of TIM6                                                  | . 212 |
| Figure 10-2 Counter timing diagram with prescaler division change from 1 to 4      | . 213 |
| Figure 10-3 Timing diagram of up-counting. The internal clock divider factor = 2/N | . 214 |
| Figure 10-4 Timing diagram of the up-counting, update event when ARPEN=0/1         | . 215 |
| Figure 10-5 Control circuit in normal mode, internal clock divided by 1            | . 216 |
| Figure 11-1 Functional block diagram of the independent watchdog module            | . 222 |
| Figure 12-1 Block diagram of ADC                                                   | . 229 |
| Figure 12-2 Timing diagram                                                         | . 232 |
| Figure 13-1 Comparator system connection diagram                                   | . 242 |
| Figure 14-1 I2C functional block diagram                                           | . 251 |
| Figure 14-2 I2C bus protocol                                                       | . 251 |
| Figure 14-3 Slave transmitter transfer sequence diagram                            | . 254 |
| Figure 14-4 Slave receiver transfer sequence diagram                               | . 255 |
| Figure 14-5 Master transmitter transfer sequence diagram                           | . 257 |
| Figure 14-6 Master receiver transfer sequence diagram                              | . 259 |
| Figure 15-1 UART block diagram                                                     | . 275 |
| Figure 15-2 Word length = 8 setting                                                | . 276 |
| Figure 15-3 Word length = 9 setting                                                | . 276 |



| Figure 15-4 Stop bit configuration                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------|
| Figure 15-5 TXC/TXDE changes during transmission                                                                               |
| Figure 15-6 Start bit detection                                                                                                |
| Figure 15-7 Mute mode using idle line detection                                                                                |
| Figure 15-8 Mute mode detected using address mark                                                                              |
| Figure 16-1 SPI block diagram                                                                                                  |
| Figure 16-2 Slave selects management of hardware/software                                                                      |
| Figure 16-3 Master and slave applications                                                                                      |
| Figure 16-4 Data clock timing diagram                                                                                          |
| Figure 16-5 Schematic diagram of the change of TE/RNE/BUSY when the host is continuously transmitting in full duplex mode      |
| Figure 16-6 Schematic diagram of TE/BUSY change when the host transmits continuously in one-way only mode                      |
| Figure 16-7 Schematic diagram of RNE change when continuous transmission occurs in receive-only mode (BIDIRMODE=0 and RONLY=1) |
| Figure 16-8 Schematic diagram of the change of TE/RNE/BUSY when the slave is continuously transmitting in full duplex mode     |
| Figure 16-9 Schematic diagram of TE/BUSY change during continuous transmission in slave unidirectional transmit-only mode      |
| Figure 16-10 Schematic diagram of TE/BUSY change when BIDIRMODE = 0 and RONLY = 0 are transmitted discontinuously              |
| Figure 18-1 N32G003 level and Cortex®-M0 level debugging block diagram                                                         |



## 1 Abbreviations in the text

## 1.1 List of abbreviations for registers

The following abbreviations are used in register descriptions:

| read/write(rw)                | Software can read and write these bits.                                            |
|-------------------------------|------------------------------------------------------------------------------------|
| read-only(r)                  | Software can only read these bits.                                                 |
| write-only(w)                 | Software can only write this bit, and reading this bit will return the reset       |
|                               | value.                                                                             |
| read/clear(rc_w1)             | Software can read this bit or clear it by writing' 1', and writing' 0' has no      |
|                               | effect on this bit.                                                                |
| read/clear(rc_w0)             | Software can read this bit or clear it by writing' 0', and writing' 1' has no      |
|                               | effect on this bit.                                                                |
| read/clear by read(rc_r)      | Software can read this bit. Reading this bit will automatically clear it to' 0'.   |
|                               | Writing' 0' has no effect on this bit.                                             |
| read/set(rs)                  | Software can read or set this bit. Writing' 0' has no effect on this bit.          |
| read-only write trigger(rt_w) | Software can read this bit and write' 0' or' 1' to trigger an event, but it has no |
|                               | effect on this bit value.                                                          |
| toggle(t)                     | Software can only flip this bit by writing' 1', and writing' 0' has no effect on   |
|                               | this bit.                                                                          |
| Reserved(Res.)                | Reserved bit, must be kept at reset value.                                         |

## **1.2 Available peripherals**

For all models of N32G003 microcontroller series, the existence and number of a peripheral, please refer to the data sheet of the corresponding model.



## 2 Memory and bus architecture

## 2.1 System architecture

## 2.1.1 **Bus architecture**

The main system consists of the following parts:

- One master device:
  - ♦ Cortex®-M0 core
- Five slave devices:
  - ♦ Internal flash memory
  - ♦ Internal SRAM
  - ♦ AHB2AHB bridge, which connects AHB modules
  - ♦ ADC
  - ♦ AHB2APB bridge, which connects APB modules

The system bus architecture is shown as in Figure 2-1:



#### Figure 2-1 Bus architecture



- CPU System bus: Connects to the Cortex<sup>®</sup>-M0 kernel bus to bus matrix, used for instruction pre-fetch, data load (constant load and debug access) and AHB/APB peripheral access.
- The bus matrix coordinates access arbitration the kernel system bus. The bus matrix consists of only 1 driver components (CPU system bus) and five slave components (flash memory interface, SRAM, ADC, AHB and APB system bus). Some AHB peripherals are connected to system bus through a bus matrix.
- The system consists of 1 AHB2APB Bridges. APB contains 16 APB peripherals and the maximum speed of PCLK is 48MHz.

## 2.1.2 Bus address mapping

The address mapping includes all AHB peripherals, APB peripherals, Flash, SRAM, System Memory, etc. The specific mapping is as follows:



#### Figure 2-2 Bus address map



#### Table 2-1 List of peripheral register addresses

| Address range             | Peripherals | Bus |  |  |
|---------------------------|-------------|-----|--|--|
| 0x4002_3400 - 0x5FFF_FFFF | Reserved    |     |  |  |
| 0x4002_3000 - 0x4002_33FF | CRC         |     |  |  |
| 0x4002_2400 - 0x4002_2FFF | Reserved    |     |  |  |
| 0x4002_2000 - 0x4002_23FF | FLASH       |     |  |  |
| 0x4002_1400 - 0x4002_1FFF | Reserved    | AHB |  |  |
| 0x4002_1000 - 0x4002_13FF | RCC         |     |  |  |
| 0x4002_0C00 - 0x4002_0FFF | Reserved    |     |  |  |
| 0x4002_0800 - 0x4002_0BFF | ADC         |     |  |  |
| 0x4002_0000 - 0x4002_07FF | Reserved    |     |  |  |
| 0x4000_7400 - 0x4001_FFFF | Reserved    |     |  |  |
| 0x4000_7000 - 0x4000_73FF | PWR         |     |  |  |
| 0x4000_5C00 - 0x4000_6FFF | Reserved    | APB |  |  |
| 0x4000_5800 - 0x4000_5BFF | SPI         |     |  |  |
| 0x4000_5400 - 0x4000_57FF | I2C1        |     |  |  |



| Address range             | Peripherals | Bus |
|---------------------------|-------------|-----|
| 0x4000_4C00 - 0x4000_53FF | Reserved    |     |
| 0x4000_4800 - 0x4000_4BFF | UART2       |     |
| 0x4000_4400 - 0x4000_47FF | UART1       |     |
| 0x4000_3C00 - 0x4000_4300 | Reserved    |     |
| 0x4000_3800 - 0x4000_3BFF | BEEPER      |     |
| 0x4000_3400 - 0x4000_37FF | EXTI        |     |
| 0x4000_3000 - 0x4000_33FF | Reserved    |     |
| 0x4000_2C00 - 0x4000_2FFF | IWDG        |     |
| 0x4000_2800 - 0x4000_2BFF | Reserved    |     |
| 0x4000_2400 - 0x4000_27FF | СОМР        |     |
| 0x4000_2000 - 0x4000_23FF | GPIOB       |     |
| 0x4000_1C00 - 0x4000_1FFF | GPIOA       |     |
| 0x4000_1800 - 0x4000_1BFF | Reserved    |     |
| 0x4000_1400 - 0x4000_17FF | AFIO        |     |
| 0x4000_1000 - 0x4000_13FF | TIM6        |     |
| 0x4000_0C00 - 0x4000_0FFF | TIM1        |     |
| 0x4000_0800 - 0x4000_0BFF | Reserved    |     |
| 0x4000_0400 - 0x4000_07FF | TIM3        |     |
| 0x4000_0000 - 0x4000_03FF | Reserved    |     |

### 2.1.3 **Boot management**

#### 2.1.3.1 Boot address

During system startup, after a startup delay, the CPU gets the address at the top of the stack from address 0x0000\_0000 and executes the code from the reset vector address indicated by address 0x0000\_0004.Because of the Cortex<sup>®</sup>-M0 always gets the stack top pointer and reset vector from addresses 0x0000\_0000 and 0x0000\_0004, so boot is only suitable for starting from the CODE area, and address remapping is designed for boot space.

- Boot from Main Flash memory:
  - Main flash memory is mapped to the boot space (0x0000\_0000);
  - ♦ Main flash memory is accessible in two address areas, 0x0000\_0000 or 0x0800\_0000;

## 2.2 Memory system

The program memory, data memory, registers and I/O ports are organized in the same 4GB linear address space. Data bytes are stored in the memory in little endian format. The lowest address byte in a word is regarded as the least significant byte of the word, while the highest address byte is the most significant byte. The specifications of program memory and data memory are as follows.

## 2.2.1 **FLASH specification**

Flash consists of the main memory area and the information area, which are described separately below:



- The maximum size of the main memory area is 29.5KB, also known as primary flash memory, and contains 59 pages for the storage and running of user programs, as well as data memory.
- The information area is 2KB, containing 4 pages, which is composed of the system configuration area (1.5KB), and option byte area (0.5KB):
  - The system configuration area is 1.5KB and contains three pages.
  - OptionByte area is 0.5KB, including 1 Page, the effective space is 16B, user programs can read and write erase.

#### 2.2.1.1 Flash memory module organization

Bus address space is allocated to the main storage area and the information area.

| Memory area        | Page name                 | Address range             | Size   |
|--------------------|---------------------------|---------------------------|--------|
|                    | Page 0                    | 0x0800_0000 - 0x0800_01FF | 0.5 KB |
|                    | Page 1                    | 0x0800_0200 - 0x0800_03FF | 0.5 KB |
| The main memory    | Page 2                    | 0x0800_0400 - 0x0800_05FF | 0.5 KB |
| area               | :                         | :                         | ÷      |
|                    | Page 58                   | 0x0800_7400 - 0x0800_75FF | 0.5 KB |
| Information and    | System configuration area | 0x1FFF_F000 – 0x1FFF_F5FF | 1.5 KB |
| Information area   | Option byte area          | 0x1FFF_F600 - 0x1FFF_F60F | 16B    |
|                    | FLASH_AC                  | 0x4002_2000 - 0x4002_2003 | 4B     |
|                    | FLASH_KEY                 | 0x4002_2004 - 0x4002_2007 | 4B     |
|                    | FLASH_OPTKEY              | 0x4002_2008 - 0x4002_200B | 4B     |
|                    | FLASH_STS                 | 0x4002_200C - 0x4002_200F | 4B     |
| Memory area        | FLASH_CTRL                | 0x4002_2010 - 0x4002_2013 | 4B     |
| interface register | FLASH_ADD                 | 0x4002_2014 - 0x4002_2017 | 4B     |
|                    | Reserved                  | 0x4002_2018 - 0x4002_201B | 4B     |
|                    | FLASH_OB                  | 0x4002_201C - 0x4002_201F | 4B     |
|                    | FLASH_USER2               | 0x4002_2020 - 0x4002_2023 | 4B     |
|                    | FLASH_VTOR                | 0x4002_2024 - 0x4002_2027 | 4B     |

#### Table 2-2 Flash bus address list

Flash memory is organized into 32-bit wide memory cells that can hold code and data constants.

The information area is divided into two parts:

- System configuration area, which contains basic chip information.
- Option byte area.

Writing to main memory and information block is managed by embedded flash programming/erasing controller.

There is two ways to protect flash memory from illegal access (read, write and erase):

- Permissions protect
- Readout protection (RDP)



When performing flash programming operations (write or erase), the internal RC oscillator (HSI) must be turned on.

When the flash memory write operation is executed, any read operation to the flash memory will lock the bus, and the read operation can only be carried out correctly after the write operation is completed. That is, when writing or erasing, cannot have any read access to the code or data.

The internal RC oscillator (HSI) must be turned on when the flash memory is programmed (written or erased).

Note: In the low power consumption mode, all flash memory operations are suspended.

#### 2.2.1.2 Read and write operation

The Flash operation only supports 32-bit operation, and the Flash should be erased before the write operation, and the minimum block size for erasing is one Page 0.5KB. Write operation is divided into erasing and programming phases.

When reading Flash, the number of waiting cycles for reading can be configured by the register. When using, it needs to be calculated in combination with the clock frequency of SYSCLK interface. For example, when SYSCLK <= 24MHz, the minimum number of waiting periods is 0; When 24MHz< SYSCLK <= 48MHz, the minimum number of waiting periods is 1.

Note: Enable prefetch buffer whether number of wait periods is not zero can improve overall efficiency.

#### 2.2.1.3 Unlock Flash

After reset, the Flash module is protected and cannot be written into the FLASH\_CTRL register to prevent accidental operation of Flash due to electrical interference and other reasons. By writing a specific sequence of key values into the FLASH\_KEY register, you can open the operation authority of the FLASH\_CTRL register. The specific sequence is: Firstly, writing KEY1 = 0x45670123 in the FLASH\_KEY register. Secondly, write KEY2 = 0xCDEF89AB in the FLASH\_KEY register.

If there is an error in sequence or key value, a bus error will be returned and the FLASH\_CTRL register will be locked until the next reset. The software can check whether the Flash has been unlocked by looking at the FLASH\_CTRL.LOCK bit. If normal lock setting is needed, it can be realized by setting the FLASH\_CTRL.LOCK bit to 1 by software. After that, you can unlock the Flash by writing the correct key value series in FLASH\_KEY.

#### 2.2.1.4 Erase and program

#### 2.2.1.4.1 Main memory area erased

The main memory area can be erased page by page or whole.

#### Page Erase

Page Erase process(when FLASH\_OB.BOOT\_LOCK = 1, then first 3K not erase):

- Check the FLASH\_STS.BUSY bit to confirm that there are no other flash operations in progress;
- Set the FLASH\_CTRL.PER bit to '1';
- Select the page to be erased with the FLASH\_ADD register;
- Set the FLASH\_CTRL.START bit to '1';
- Wait for the FLASH\_STS.BUSY bit to change to '0';



Read out the erased page and verify it.

#### **Mass Erase**

Mass Erase process:

- Check the FLASH\_STS.BUSY bit to confirm that there are no other flash operations in progress;
- Set the FLASH\_CTRL.MER bit to '1';
- Set the FLASH\_CTRL.START bit to '1';
- Wait for the FLASH\_STS.BUSY bit to change to '0';
- Read out all pages and verify.

#### 2.2.1.4.2 Main memory area programming

The main memory area can be programmed with 32 bits at a time. When the FLASH\_CTRL.PG bit is '1', writing a word in a flash address will start programming once; Writing any half word of data will result in a bus error. During the programming process (the FLASH\_STS.BUSY bit is '1'), any operation of reading or writing the flash memory will cause the CPU to pause until the end of the flash programming.

Main memory programming process:

- Check the FLASH\_STS.BUSY bit to confirm that there are no other flash operations in progress;
- Set the FLASH\_CTRL.PG bit to '1';
- Write the word to be programmed at the specified address;
- Wait for the FLASH\_STS.BUSY bit to change to '0';
- Read the written address and verify the data.

*Note: When the FLASH\_STS.BUSY bit is '1', you cannot write to any register.* 

#### 2.2.1.4.3 Option byte erase and programming

The option byte area is programmed differently from the main storage area. The number of option bytes is only 8 bytes (2 bytes for read protection, 4 byte for configuration options, and 2 bytes for user data memory). After unlocking the Flash, you must write KEY1 and KEY2 respectively (see section 2.2.1.3) to the FLASH\_OPTKEY register, and then set the FLASH\_CTRL.OPTWE bit to '1'. At this time, the option byte area can be programmed: set the FLASH\_CTRL.OPTPG bit to '1' and then write the word to the specified address.

When programming the word in the option byte area, use the low byte in the half-word and automatically calculate the high byte (the high byte is the complement of the low byte), and start the programming operation, which will ensure that the option byte and its complement are always correct.

Option byte erase process:

- Check the FLASH\_STS.BUSY bit to confirm that there are no other flash operations in progress;
- Unlock the FLASH\_CTRL.OPTWE bit;
- Set the FLASH\_CTRL.OPTER bit to '1';
- Set the FLASH\_CTRL.START bit to '1';

# Nation 🚯

- Wait for the FLASH\_STS.BUSY bit to change to '0';
- Read the erased option byte and verify it.

Option byte area programming process:

- Check the FLASH\_STS.BUSY bit to confirm that there are no other flash operations in progress;
- Unlock the FLASH\_CTRL.OPTWE bit;
- Set the FLASH\_CTRL.OPTPG bit to '1';
- Writing the word to be programmed to the specified address;
- Wait for the FLASH\_STS.BUSY bit to change to '0';
- Read the written address and verify the data.

#### 2.2.1.5 Instruction prefetching

The instruction prefetch function of Flash module supports the prefetch Buffer of 8B. Through instruction prefetching, the instruction execution efficiency of CPU can be improved. The instruction prefetch function can be configured to be enabled or disabled through the register, and it is enabled by default.

#### 2.2.1.6 **Option byte**

Option byte blocks are used to configure read protection, software/hardware watchdog, and reset options when the system is in power-off or shutdown mode. In addition, bus address space is allocated for read/write access. They consist of 8 option bytes: 2 bytes for read protection, 4 byte for configuration options, and 2 bytes defined by the user, which need to be written across the bus. The option byte block also contains the inverse codes corresponding to the 8 option bytes, which are automatically calculated by the hardware when the bus writes the option bytes, written to Flash, and used for verification when the option bytes are read.

By default, option byte blocks are always readable and write-protected. To write to the option byte block (program/erase), first unlock the flash, and then unlock the option byte: write the correct sequence of key values in OPTKEY (KEY1 = 0x45670123, KEY2 = 0xCDEF89AB), and then write to the option byte block will be allowed. If the order is wrong or the key value is wrong, the bus error is returned and the option bytes are locked until the next reset. To properly set the lock, write the OPTWE bit 0 in the FLASH\_CTRL register by software, and then unlock the option bytes by writing the correct key series to the FLASH\_OPTKEY.

After each system reset, the option byte data is read from the option byte block of Flash and saved in the option byte register (FLASH\_OB/FLASH\_USER) with read-only properties. The option byte inverse data, read together, is used to verify that the option byte data is correct, and if it does not match, an option byte error flag (FLASH\_OB.OBERR) is generated. When an option byte error occurs, the corresponding option byte is forced to 0xFF.If both the optional byte and its inverse code are 0xFF (the erased state), the above verification steps are skipped and no verification is required.



#### Table 2-3 Option byte list

| Address     | [31:24]<br>Corresponding<br>complement code | [23:16]<br>Option byte | [15:8]<br>Corresponding<br>complement code | [7:0]<br>Option byte |
|-------------|---------------------------------------------|------------------------|--------------------------------------------|----------------------|
| 0x1FFF_F600 | nUSER                                       | USER                   | nRDP1                                      | RDP1                 |
| 0x1FFF_F604 | nData1                                      | Data1                  | nData0                                     | Data0                |
| 0x1FFF_F608 | nUSER3                                      | USER3                  | nUSER2                                     | USER2                |
| 0x1FFF_F60C | nUSER4                                      | USER4                  | nRDP2                                      | RDP2                 |

- Configuration option: USER
  - ♦ USER[7:5]: Reserved;
  - USER[4]: NRST\_PA0 configuration option, which can be queried by FLASH\_OB[6]
    - 0: PA0 as a normal GPIO pin
    - 1: PA0 as NRST pin
  - USER[3]: BOOT\_LOCK configuration option, which can be queried by FLASH\_OB[5]
    - 0: Flash first 3KB is not locked
    - 1: Flash first 3KB is locked
  - USER[2]: nRST\_PD configuration option, which can be queried through FLASH\_OB[4]
    - 0: A reset occurs when PD mode is entered
    - 1: No reset occurs when entering PD mode
  - USER[1]: nRST\_STOP configuration option, which can be queried through FLASH\_OB[3]
    - 0: A reset occurs when entering STOP mode
    - 1: No reset occurs when entering the STOP mode
  - USER[0]: WDG\_SW configuration option, which can be queried by FLASH\_OB[2]
    - 0: Hardware watchdog
    - 1: Software watchdog
- Two bytes of user data: Datax
  - Data1 (stored in FLASH\_OB[25:18]);
  - Data0 (stored in FLASH\_OB[17:10]);
- Configuration options bytes:
  - USER2[7:0]: LVR filter counter control, which can be queried through FLASH\_USER[7:0]
  - USER3[3:0]: LVR power on level configure, which can be queried through FLASH\_USER[11:8]
  - USER3[4]: LVR enable, which can be queried through FLASH\_USER[12]
  - USER3[5]: LVR filter enable, which can be queried through FLASH\_USER[13]



- USER3[6]: LVR reset enable, which can be queried through FLASH\_USER[14]
- USER4[7:0]: Power on delay reset control, , which can be queried through FLASH\_USER[23:16]

Note: When USER and nUSER are both 0xFF, it is the erased state, the function of the corresponding bit is invalid, and it needs to be programmed to be in the inverse code state to take effect

- Read protection L1 level option byte: RDP1
  - Protect code stored in flash memory;
  - When the correct value is written, writing to the flash memory via SWD is disallowed;
  - The result of whether RDP1 is enabled can be queried by running FLASH\_OB[1].
- Read protection L2 level option byte: RDP2
  - Add protection function on the basis of L1. For details, see 2.2.1.9 Read Protection.
  - The result of whether RDP2 is enabled can be queried by running FLASH\_OB[31];

#### 2.2.1.7 Read protection

The user code in flash can be protected from illegal reading by setting read protection. Read protection is set by configuring RDP bytes in the option byte block. Three different read protection levels can be configured, as shown in the following Table

#### Table 2-4 Read protection configuration list

| Read protection status | RDP1                                       | nRDP1 | nRDP2                                  | RDP2 |
|------------------------|--------------------------------------------|-------|----------------------------------------|------|
| L1 level               | 0xFF                                       | 0xFF  | $RDP2! = 0xCC \parallel nRDP2! = 0x33$ |      |
| L0 level               | 0xA5                                       | 0x5A  | $RDP2! = 0xCC \parallel nRDP2! = 0x33$ |      |
| L2 level               | 0xXX                                       | 0xXX  | 0x33                                   | 0xXX |
| L1 level               | None of the preceding three configurations |       |                                        |      |

<sup>■</sup> L0 level:

- ♦ In the unprotected state, the corresponding (RDP1 = 0xA5&NRDP1 = 0x5A) && (RDP2 != 0xCC | nRDP2 != 0 x33);
- Main memory and option byte blocks can be read arbitrarily
- Can be rewritten to L1 or L2 level
- L1 level:
  - The corresponding ~(((RDP1 = 0x5&nrdP1 = 0x5A) && (RDP2 != 0xCC | nRDP2 != 0 x33) || (RDP2 = 0 XCC & nRDP2 = 0 x33));
  - Can rewrite for L2 or level of L0, when change the form of the option bytes have been read to protect unprotected L0 level will automatically be erased all the main memory area, execution process is as follows: (erase the option byte block does not lead to the entire automatically erase operation, because of erasing the result is 0xFF, equivalent to a still in a state of L1 level of protection)
    - Write the correct sequence of keys to the OPTKEY unlock option byte area;



- The bus initiates the command to erase the entire option byte area (Page erase);
- Bus write read protection option byte 0xA5;
- Internal automatic erasure of all main memory areas;
- Internally write 0xA5 to read protection option bytes;
- System reset (such as software reset, etc.), option byte blocks (including the new RDP value 0xA5) will be reloaded into the system, and read protection will be removed;
- All functions of loading and executing code into the built-in SRAM via SWD are still valid, and can also be enabled from the built-in SRAM via SWD. This function can be used to remove read protection.
- L2 level:
  - The L2 level is achieved by configuring another option byte RDP2, regardless of the value of RDP1, as long as (RDP2 = 0xCC & nRDP2 = 0x33) the LEVEL is L2.
  - The protection level cannot be changed (irreversible).
  - Features are at L1 level except that option byte write/page erase and SWD is disabled.

#### 2.2.1.8 **Permission Protection**

- Flash main memory permissions:
  - ◆ At the L0 level: all main memory areas can be read. When FLASH\_OB.BOOT\_LOCK = 0, then first 3K byte can write and erase; when FLASH\_OB.BOOT\_LOCK = 1, then first 3K byte can not write and erase.
  - At the L1/2 level:
    - The first 3K byte read-only, other content access is allowed (W/R/PE) when code execution in FLASH/SRAM;
    - SWD disable access to FLASH/SRAM
    - When the L1 level is changed to L0, all Flash main memory areas are automatically erased.
- Flash options byte area permissions:
  - At the L0/L1 level, access is allowed (W/R/PE).
  - L2 level: Read-only access to flash option bytes is allowed except for debugging mode.
- Flash system configuration area
  - after seal, read-only

#### Table 2-5 Flash read-write-erase permission control table

| protect          | Boot mode                        | Flash            |                  | Changing a                     |
|------------------|----------------------------------|------------------|------------------|--------------------------------|
| protect<br>level | Perform user<br>Access area      | Flash/SRAM       | SWD              | Changing a<br>Protection Level |
| L0               | Flash main memory area first 3KB | Read-Write-Erase | Read-Write-Erase | Change to L1 or L2 is          |
| Level            | FLASH_OB.BOOT_LOCK = 0           | Reau-wille-Erase | Reau-wille-Erase | allowed                        |



|       | Flash main memory area first 3KB<br>FLASH_OB.BOOT_LOCK = 1 | Only read        | Only read        |                                          |
|-------|------------------------------------------------------------|------------------|------------------|------------------------------------------|
|       | After flash main memory area first 3KB                     | Read-Write-Erase | Read-Write-Erase |                                          |
|       | Flash main memory area mass erase <sup>(1)</sup>           | Allow            | Allow            |                                          |
|       | Flash option byte area                                     | Read-Write-Erase | Read-Write-Erase |                                          |
|       | System configuration area                                  | Only read        | Only read        |                                          |
|       | SRAM (All)                                                 | Read-Write       | Read-Write       |                                          |
|       | Flash main memory area first 3KB<br>FLASH_OB.BOOT_LOCK = 0 | Only read        |                  |                                          |
|       | Flash main memory area first 3KB<br>FLASH_OB.BOOT_LOCK = 1 | Only read        | Forbid           | Change to L0 or L2 is allowed.           |
| L1    | After flash main memory area first 3KB                     | Read-Write-Erase |                  | When changed to L0,                      |
| Level | Flash main memory area mass erase <sup>(1)</sup>           | Allow            | Forbid           | the main memory<br>area is automatically |
|       | Flash option byte area                                     | Read-Write-Erase | Read-Write-Erase | erased                                   |
|       | System configuration area                                  | Only read        | Only read        | crased                                   |
|       | SRAM (All)                                                 | Read-Write       | Forbid           |                                          |
|       | Flash main memory area first 3KB<br>FLASH_OB.BOOT_LOCK = 0 | Only read        |                  |                                          |
|       | Flash main memory area first 3KB<br>FLASH_OB.BOOT_LOCK = 1 | Only read        |                  |                                          |
| L2    | After flash main memory area first 3KB                     | Read-Write-Erase | Forbid           | No modification is                       |
| Level | Flash main memory area mass erase <sup>(1)</sup>           | Allow            |                  | allowed                                  |
|       | Flash option byte area                                     | Only read        |                  |                                          |
|       | System configuration area                                  | Only read        |                  |                                          |
|       | SRAM (All)                                                 | Read-Write       |                  |                                          |

Note:

1. Mean mass erase, when FLASH\_OB.BOOT\_LOCK = 1, then first 3K not erase.

## 2.2.2 **SRAM**

SRAM is mainly used for code running, storing variables and data or stacks during program execution, with a maximum capacity of 3KB.

SRAM supports byte, half word, word read and write access.

SRAM supports code running and can run programs at full speed in SRAM. The maximum address range of SRAM is 0x2000 0000 to 0x2000 0BFF.

SRAM cannot hold data in PD mode; Data in Stop mode can be maintained.

The main features are as follows:

- The maximum total capacity is 3KB
- Support byte/half word/word reading and writing



- CPU access
- The CPU BUS can remap to SRAM to run the program at full speed

## 2.2.3 FLASH register description

These peripheral registers must be operated as words (32 bits).

### 2.2.3.1 FLASH register overview

Table 2-6 FLASH register overview

| Offset | Register     | 31     | 30 | 29 | 28     | 27 | 26       | 25       | 24   | 23       | 22       | 21   | 20       | 19    | 18   | 17  | 16       | 15       | 14 | 13        | 12       | Ξ        | 10       | 6        | ~        | 7        | 6        | 5         | 4       | 3         | 2      | -             | 0     |
|--------|--------------|--------|----|----|--------|----|----------|----------|------|----------|----------|------|----------|-------|------|-----|----------|----------|----|-----------|----------|----------|----------|----------|----------|----------|----------|-----------|---------|-----------|--------|---------------|-------|
| 000h   | FLASH_AC     |        |    | 1  |        |    | <u> </u> | <u> </u> |      | <u> </u> | <u> </u> |      | <u> </u> | Rese  | 1    |     | <u> </u> | <u> </u> |    |           |          | <u> </u> | PRFTBFS   | PRFTBFE | Reserved  | LA     | TENC          | CY    |
|        | Reset Value  |        |    |    |        |    |          |          |      |          |          |      |          |       |      |     |          |          |    |           |          |          |          |          |          |          |          | 1         | 1       | ×.        | 0      | 0             | 0     |
| 00.41  | FLASH_KEY    |        |    |    |        |    |          |          |      |          |          |      |          |       |      |     | FK       | EY       |    |           |          |          |          |          |          |          |          |           |         |           |        |               |       |
| 004h   | Reset Value  | 0      | 0  | 0  | 0      | 0  | 0        | 0        | 0    | 0        | 0        | 0    | 0        | 0     | 0    | 0   | 0        | 0        | 0  | 0         | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0         | 0       | 0         | 0      | 0             | 0     |
| 0001   | FLASH_OPTKEY |        |    |    |        |    |          |          |      |          |          |      |          |       |      |     | OPT      | KEY      |    |           |          |          |          |          |          |          |          |           |         |           |        |               |       |
| 008h   | Reset Value  | 0      | 0  | 0  | 0      | 0  | 0        | 0        | 0    | 0        | 0        | 0    | 0        | 0     | 0    | 0   | 0        | 0        | 0  | 0         | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0         | 0       | 0         | 0      | 0             | 0     |
| 00Ch   | FLASH_STS    |        |    |    |        |    |          |          |      |          |          | -    | Res      | erved |      |     |          |          |    |           | <u> </u> |          |          |          |          | ECCERR   | Reserved | EOP       | WRPERR  | Reserved  | PGERR  | Reserved      | BUSY  |
|        | Reset Value  |        |    |    |        |    |          |          |      |          |          |      |          |       |      |     |          |          |    |           |          |          |          |          | _        | 0        | R        | 0         | 0       | R         | 0      | R             | 0     |
| 010h   | FLASH_CTRL   |        |    |    |        |    |          |          |      | Rese     | rved     |      |          |       |      |     |          |          |    | ECCERRITE | EOPITE   | Reserved | ERRITE   | OPTWE    | Reserved | LOCK     | START    | OPTER     | OPTPG   | Reserved  | MER    | PER           | Ðd    |
|        | Reset Value  |        |    |    |        |    |          |          |      |          |          |      |          |       |      |     |          |          |    | 0         | 0        |          | 0        | 0        |          | 1        | 0        | 0         | 0       |           | 0      | 0             | 0     |
|        | FLASH_ADD    |        |    |    |        |    |          |          |      |          |          |      |          |       |      |     | FA       | DD       |    |           |          |          |          |          |          |          |          | L         |         |           |        |               |       |
| 014h   | Reset Value  | 0      | 0  | 0  | 0      | 0  | 0        | 0        | 0    | 0        | 0        | 0    | 0        | 0     | 0    | 0   | 0        | 0        | 0  | 0         | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0         | 0       | 0         | 0      | 0             | 0     |
| 018h   |              |        |    |    |        |    | <u>.</u> |          |      |          |          |      |          | Re    | eser | ved | <u> </u> |          |    |           |          |          |          |          |          |          |          |           |         |           |        |               |       |
| 01Ch   | FLASH_OB     | RDPRT2 |    | R  | eserve | ed |          |          |      |          | Da       | ıta1 |          |       |      |     |          |          | Da | ta0       |          |          |          | -        | Keserved | Reserved | NRST_PA0 | BOOT_LOCK | nRST_PD | nRST_STOP | WDG_SW | <b>RDPRT1</b> | OBERR |
|        | Reset Value  | 0      |    |    |        |    |          | 1        | 1    | 1        | 1        | 1    | 1        | 1     | 1    | 1   | 1        | 1        | 1  | 1         | 1        | 1        | 1        | 1        | 1        | 1        | 1        | 0         | 1       | 1         | 1      | 0             | 0     |
| 0201   | FLASH_WRP    |        |    |    |        |    |          |          | D    |          |          |      |          |       |      |     |          |          |    |           |          |          |          |          | WR       | RPT      |          |           |         |           |        |               |       |
| 020h   | Reset Value  |        |    |    |        |    |          |          | Rese | rved     |          |      |          |       |      |     |          | 1        | 1  | 1         | 1        | 1        | 1        | 1        | 1        | 1        | 1        | 1         | 1       | 1         | 1      | 1             | 1     |
| 024h   | FLASH_ECC    |        |    |    |        |    |          |          |      |          |          |      |          | Rese  | erve | ed  |          |          |    |           |          |          |          |          |          |          |          |           |         | EC        | C      |               |       |
|        | Reset Value  |        |    |    |        |    |          |          |      |          |          |      |          |       |      |     |          |          |    |           |          |          |          |          |          |          |          | 0         | 0       | 0         | 0      | 0             | 0     |

## 2.2.3.2 FLASH access control register (FLASH\_AC)

Address offset: 0x00

Reset value: 0x0000 0030



| 31 |   |          |      |       |   |          |       |   |         |         |      |       |      | 16  |
|----|---|----------|------|-------|---|----------|-------|---|---------|---------|------|-------|------|-----|
|    |   |          |      |       |   | Rese     | erved |   |         |         |      |       |      |     |
| 15 | 1 | <u>.</u> | 1    |       |   | <u>.</u> |       | 6 | 5       | 4       | 3    | 2     | 1    | 0   |
|    | 1 | 1        | Rese | erved | 1 | 1        |       |   | PRFTBFS | PRFTBFE | Rese | erved | LATE | NCY |
|    |   |          |      |       |   |          |       |   | r       | rw      |      |       | rv   | v   |

| Bit field | Name     | Description                                                                           |
|-----------|----------|---------------------------------------------------------------------------------------|
| 31:6      | Reserved | Reserved, the reset value must be maintained.                                         |
| 5         | PRFTBFS  | Pre-fetch buffer status                                                               |
|           |          | This bit indicates the state of the pre-fetch buffer                                  |
|           |          | 0: The pre-fetch buffer is disabled.                                                  |
|           |          | 1: The pre-fetch buffer is enabled.                                                   |
| 4         | PRFTBFE  | Pre-fetch buffer is enabled                                                           |
|           |          | 0: Disables the pre-fetch buffer.                                                     |
|           |          | 1: Enables the pre-fetch buffer.                                                      |
| 3:2       | Reserved | Reserved, the reset value must be maintained                                          |
| 1:0       | LATENCY  | Time delay                                                                            |
|           |          | These bits represent the ratio of the SYSCLK (system clock) cycle to the flash access |
|           |          | time                                                                                  |
|           |          | 00: Zero periodic delay, when $0 < SYSCLK \le 24MHz$                                  |
|           |          | 01: A periodic delay, when $24MHz < SYSCLK \le 48MHz$                                 |
|           |          | Others: Reserved                                                                      |

### 2.2.3.3 FLASH key register (FLASH\_KEY)

#### Address offset: 0x04

#### Reset value: 0xXXXX XXXX

| 31 |   | <br> | <br> | <br> | -       |  |   | <br> | <br>16 |
|----|---|------|------|------|---------|--|---|------|--------|
|    | I |      |      | FKEY | [31:16] |  | I | <br> |        |
|    | 1 |      |      | ·    | w       |  | 1 |      |        |
| 15 | - | <br> | <br> | <br> |         |  |   | <br> | <br>0  |
|    |   |      |      | FKEY | [15:0]  |  | 1 |      |        |
|    | 1 |      |      |      | w       |  |   |      |        |

| Bit field | Name | Description                             |
|-----------|------|-----------------------------------------|
| 31:0      | FKEY | Used to unlock the FLASH_CTRL.LOCK bit. |

## 2.2.3.4 FLASH OPTKEY register (FLASH\_OPTKEY)

#### Address offset: 0x08

Reset value: 0xXXXX XXXX



| 31 |   |   |   |   |   |    |       |          |   | <br>     |   | <br>    | 16 |
|----|---|---|---|---|---|----|-------|----------|---|----------|---|---------|----|
|    | I | 1 | I | I |   |    | OPTKE | Y[31:16] | I |          |   | <br>ı ı |    |
|    | 1 | 1 | 1 | 1 | I | LI |       |          |   | <u> </u> | L | II      |    |
| 15 |   |   |   |   |   |    | v     | v        |   |          |   |         | 0  |
|    | 1 | 1 | 1 | 1 | 1 |    | OPTKE | Y[15:0]  |   |          |   |         |    |
|    |   |   |   |   |   |    | v     | v        |   |          |   |         |    |

| Bit field | Name   | Description                              |
|-----------|--------|------------------------------------------|
| 31:0      | OPTKEY | Used to unlock the FLASH_CTRL.OPTWE bit. |

### 2.2.3.5 FLASH status register (FLASH\_STS)

Address offset: 0x0C

Reset value: 0x0000 0000



| Bit field | Name     | Description                                                                             |
|-----------|----------|-----------------------------------------------------------------------------------------|
| 31:10     | Reserved | Reserved, the reset value must be maintained                                            |
| 9         | CFGERR   | Flash iniaial configuration error.                                                      |
|           |          | Whether the Flash iniaial configuration value read out in the config is consistent with |
|           |          | calibration value.                                                                      |
|           |          | 0: Right                                                                                |
|           |          | 1: Error                                                                                |
| 8         | SPRERR   | Spccial Pattern read error                                                              |
|           |          | Whether the Spccial Pattern value read out in the config is consistent with calibration |
|           |          | value.                                                                                  |
|           |          | 0: Right                                                                                |
|           |          | 1: Error                                                                                |
| 7:6       | Reserved | Reserved, the reset value must be maintained                                            |
| 5         | EOP      | End of the operation                                                                    |
|           |          | When the flash operation (programming/erasing) is complete, the hardware sets this      |
|           |          | to '1' and writing '1' clears this state.                                               |
|           |          | Note: EOP status is set for each successful programming or erasure.                     |
| 4         | WRPERR   | Write protection error                                                                  |
|           |          | When attempting to program a write protected flash address, hardware sets this to '1'   |
|           |          | and writing '1' clears this state.                                                      |
| 3         | Reserved | Reserved, the reset value must be maintained                                            |
| 2         | PGERR    | Programming errors                                                                      |
|           |          | When trying to program to an address whose content is not '0xFFFF_FFFF', the            |
|           |          | hardware sets this to '1'. Writing '1' clears this state.                               |



| Bit field | Name     | Description                                                                                      |
|-----------|----------|--------------------------------------------------------------------------------------------------|
|           |          | Note: Before programming, the FLASH_CTRL.START bit must be cleared.                              |
| 1         | Reserved | Reserved, the reset value must be maintained                                                     |
| 0         | BUSY     | Busy                                                                                             |
|           |          | This bit indicates that a flash operation is in progress. This bit is set to '1' at the start of |
|           |          | the flash operation; This bit is cleared to '0' at the end of the operation or when an           |
|           |          | error occurs.                                                                                    |

## 2.2.3.6 FLASH control register (FLASH\_CTRL)

Address offset: 0x10

Reset value: 0x0000 0080

| 31 |          |    |        |          |        |       |      |       |       |       |       |          |     |     | 16 |
|----|----------|----|--------|----------|--------|-------|------|-------|-------|-------|-------|----------|-----|-----|----|
|    |          |    | I      | 1        |        |       | Rese | erved | I     |       |       | 1        | I   |     |    |
|    | 1        | l  | 1      | I        |        |       | 1    | 1     | 1     |       |       | I        |     |     |    |
| 15 |          | 13 | 12     | 11       | 10     | 9     | 8    | 7     | 6     | 5     | 4     | 3        | 2   | 1   | 0  |
|    | Reserved |    | EOPITE | Reserved | ERRITE | OPTWE | MMER | LOCK  | START | OPTER | OPTPG | Reserved | MER | PER | PG |
|    |          |    | rw     |          | rw     | rw    | rw   | rw    | rw    | rw    | rw    |          | rw  | rw  | rw |

| Bit field | Name     | Description                                                                                |
|-----------|----------|--------------------------------------------------------------------------------------------|
| 31:13     | Reserved | Reserved, the reset value must be maintained                                               |
| 12        | EOPITE   | Allow operation completion interrupt.                                                      |
|           |          | This bit allows an interrupt to be generated when the FLASH_STS.EOP bit becomes '1'.       |
|           |          | 0: Forbid interruption.                                                                    |
|           |          | 1: Interrupts are allowed.                                                                 |
| 11        | Reserved | Reserved, the reset value must be maintained                                               |
| 10        | ERRITE   | Allow error status to be interrupted                                                       |
|           |          | This bit allows interrupts in the event of Flash errors (when                              |
|           |          | FLASH_STS.PGERR/FLASH_STS.WRPERR is set to '1').                                           |
|           |          | 0: Forbid interruption.                                                                    |
|           |          | 1: Interrupts are allowed.                                                                 |
| 9         | OPTWE    | Allows option bytes to be written                                                          |
|           |          | When the bit is '1', programmatic manipulation of the option byte is allowed. When the     |
|           |          | correct key sequence is written to the FLASH_OPTKEY register, the bit is set to '1'.       |
|           |          | Software can clear this bit.                                                               |
| 8         | MMER     | Erase main memory area.                                                                    |
|           |          | 0: None                                                                                    |
|           |          | 1: Erase main memory area first 48 page                                                    |
| 7         | LOCK     | Lock                                                                                       |
|           |          | This bit can only be written as '1'. When the bit is '1', Flash and FLASH_CTRL are locked. |
|           |          | Hardware clears this bit to '0' after detecting a correct unlock sequence.                 |
|           |          | After an unsuccessful unlock operation, this bit cannot be changed until the next system   |
|           |          | reset.                                                                                     |
| 6         | START    | Start                                                                                      |



| Bit field | Name     | Description                                                                                      |
|-----------|----------|--------------------------------------------------------------------------------------------------|
|           |          | An erase operation is triggered when the bit is '1'. This bit can only be set by software to '1' |
|           |          | and cleared to '0' when FLASH_STS.BUSY changes to '1'.                                           |
| 5         | OPTER    | Erase option bytes                                                                               |
|           |          | 0: Disable option bytes erase mode.                                                              |
|           |          | 1: Enable option bytes erase mode.                                                               |
| 4         | OPTPG    | Program option bytes                                                                             |
|           |          | 0: Disable option bytes program mode.                                                            |
|           |          | 1: Enable option bytes program mode.                                                             |
| 3         | Reserved | Reserved, the reset value must be maintained.                                                    |
| 2         | MER      | Mass erase.                                                                                      |
|           |          | Erase main memory area all pages.                                                                |
|           |          | 0: Disable mass erase mode.                                                                      |
|           |          | 1: Enable mass erase mode.                                                                       |
| 1         | PER      | Page erase                                                                                       |
|           |          | 0: Disable mass erase mode.                                                                      |
|           |          | 1: Enable mass erase mode.                                                                       |
| 0         | PG       | Program                                                                                          |
|           |          | 0: Disable Program mode.                                                                         |
|           |          | 1: Enable Program mode.                                                                          |

Note: Please refer to Section 2.2.1.4 for programming and erasing.

### 2.2.3.7 FLASH address register (FLASH\_ADD)

Address offset: 0x14

Reset value: 0x0000 0000

| 31 |   | <br> | - |      |      | -       | <br>  |   |   | <br>16 |
|----|---|------|---|------|------|---------|-------|---|---|--------|
|    | 1 | I    | I | <br> | FADD | [31:16] | <br>I | I | 1 |        |
|    | 1 |      | 1 |      | v    | v       |       | 1 | 1 |        |
| 15 |   | <br> |   |      |      |         | <br>  |   |   | <br>0  |
|    |   |      | 1 |      | FADD | [15:0]  |       | 1 | 1 |        |
|    | • |      |   |      | v    | v       |       | • |   |        |

| Bit field | Name | Description                                                                        |
|-----------|------|------------------------------------------------------------------------------------|
| 31:0      | FADD | Flash memory address                                                               |
|           |      | Select the address to program when programming and the page to erase when erasing. |
|           |      | Note: When the FLASH_STS.BUSY bit is '1', this register cannot be written.         |

## 2.2.3.8 FLASH option byte register (FLASH\_OB)

Address offset: 0x1C

Reset value: 0x03FF FFDC



| 31      | 30 |    |          |   | 26 | 25 |          |   |              |               |             |      | 18     | 17     | 16     |
|---------|----|----|----------|---|----|----|----------|---|--------------|---------------|-------------|------|--------|--------|--------|
| RDPRT2  |    |    | Reserved | 1 |    |    |          |   | Da           | ita1          | 1           |      | 1      | Da     | ta0    |
| r<br>15 |    |    |          |   | 10 | 9  | •        | 7 | 6            | r<br>5        | 4           | 3    | 2      | 1      | r<br>0 |
|         |    | Da | ita0     | 1 |    |    | Reserved |   | NRST_<br>PA0 | BOOT_<br>LOCK | nRST_<br>PD | nRST | WDG_SW | RDPRT1 | OBERR  |
|         |    |    | r        |   |    | •  |          |   | r            | r             | r           | r    | r      | r      | r      |

| Bit field        | Name       | Description                                                                                     |  |  |  |  |  |  |  |
|------------------|------------|-------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 31               | RDPRT2     | Read protection level L2                                                                        |  |  |  |  |  |  |  |
|                  |            | 0: Read protection L2 is disabled.                                                              |  |  |  |  |  |  |  |
|                  |            | 1: Read protection L2 is enabled.                                                               |  |  |  |  |  |  |  |
|                  |            | Note: This bit is read-only.                                                                    |  |  |  |  |  |  |  |
| 30:26            | Reserved   | Reserved, the reset value must be maintained                                                    |  |  |  |  |  |  |  |
| 25:18 Data1[7:0] |            | Data1                                                                                           |  |  |  |  |  |  |  |
|                  |            | Note: These bits are read-only.                                                                 |  |  |  |  |  |  |  |
| 17:10            | Data0[7:0] | Data0                                                                                           |  |  |  |  |  |  |  |
|                  |            | Note: These bits are read-only.                                                                 |  |  |  |  |  |  |  |
| 9:7              | Reserved   | Reserved, the reset value must be maintained                                                    |  |  |  |  |  |  |  |
| 6                | NRST_PA0   | PA0 pin configuration.                                                                          |  |  |  |  |  |  |  |
|                  |            | 0: Common I/O pin                                                                               |  |  |  |  |  |  |  |
|                  |            | 1: NRST pin                                                                                     |  |  |  |  |  |  |  |
|                  |            | Note: This bit is read-only.                                                                    |  |  |  |  |  |  |  |
| 5                | BOOT_LOCK  | Lock the first 3K of the main flash.                                                            |  |  |  |  |  |  |  |
|                  |            | 0: Not locked                                                                                   |  |  |  |  |  |  |  |
|                  |            | 1: Lock                                                                                         |  |  |  |  |  |  |  |
|                  |            | Note : This bit is read-only. the first 3kb flash is not erasable when locked                   |  |  |  |  |  |  |  |
| 4                | nRST_PD    | The Power Down mode is used to reset the configuration                                          |  |  |  |  |  |  |  |
|                  |            | 0: A reset occurs immediately after the system enters the Power Down mode. Even if the          |  |  |  |  |  |  |  |
|                  |            | system enters the Power Down mode, the system will be reset instead of entering the Power       |  |  |  |  |  |  |  |
|                  |            | Down mode.                                                                                      |  |  |  |  |  |  |  |
|                  |            | 1: The system does not reset after entering the Power Down mode.                                |  |  |  |  |  |  |  |
|                  |            | Note: This bit is read-only.                                                                    |  |  |  |  |  |  |  |
| 3                | nRST_STOP  | Enter the STOP mode to reset the configuration                                                  |  |  |  |  |  |  |  |
|                  |            | 0: A reset occurs immediately after entering the STOP mode. Even if the process of entering the |  |  |  |  |  |  |  |
|                  |            | STOP mode is executed, the system will be reset instead of entering the STOP mode.              |  |  |  |  |  |  |  |
|                  |            | 1: No reset is generated after the STOP mode is entered.                                        |  |  |  |  |  |  |  |
|                  |            | Note: This bit is read-only.                                                                    |  |  |  |  |  |  |  |
| 2                | WDG_SW     | Watchdog Settings                                                                               |  |  |  |  |  |  |  |
|                  |            | 0: Hardware watchdog.                                                                           |  |  |  |  |  |  |  |
|                  |            | 1: Software watchdog.                                                                           |  |  |  |  |  |  |  |
|                  |            | Note: This bit is read-only.                                                                    |  |  |  |  |  |  |  |
| 1                | RDPRT1     | Read protection level L1                                                                        |  |  |  |  |  |  |  |
|                  |            | 0: L1 level of read protection is disabled.                                                     |  |  |  |  |  |  |  |



| Bit field | Name  | Description                                                       |
|-----------|-------|-------------------------------------------------------------------|
|           |       | 1: L1 read protection is enabled.                                 |
|           |       | Note: This bit is read-only.                                      |
| 0         | OBERR | Option byte error                                                 |
|           |       | When this bit is '1', the option byte does not match its inverse. |
|           |       | Note: This bit is read-only.                                      |

### 2.2.3.9 USER register (FLASH\_USER)

Address offset: 0x20

```
Reset value: 0xFFFF FFFF
```

| 31   |       |              |       |       |      |        | 24 | 23 |   | <br>     |          | <br> | 16 |
|------|-------|--------------|-------|-------|------|--------|----|----|---|----------|----------|------|----|
|      |       |              | Rese  | erved |      |        |    |    |   | POR_DE   | LAY[7:0] |      |    |
|      | 1     | 1            | 1     | 1     |      | 1      |    |    | 1 | <br>1    | r        | <br> | I] |
| 15   | 14    | 13           | 12    | 11    |      |        | 8  | 7  |   |          |          |      | 0  |
| Rese | erved | LVR<br>FILEN | LVREN |       | LVRL | S[3:0] |    |    | 1 | <br>LVRC | NT[7:0]  |      |    |
|      |       | r            | r     |       | 1    | r      |    |    |   |          | r        |      |    |

| Bit field | Name      | Description                                                                                |  |  |  |  |  |  |  |
|-----------|-----------|--------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 31:24     | Reserved  | Reserved, the reset value must be maintained                                               |  |  |  |  |  |  |  |
| 23:16     | POR_DELAY | Delay of CPU reset after POR is triggered.                                                 |  |  |  |  |  |  |  |
|           |           | After initial system power-on, the Cortex®-M0's system dereset delay can be configured via |  |  |  |  |  |  |  |
|           |           | this bit to control the reset delay time of the core.                                      |  |  |  |  |  |  |  |
|           |           | 0x00: Maximum delay                                                                        |  |  |  |  |  |  |  |
|           |           |                                                                                            |  |  |  |  |  |  |  |
|           |           | 0xFF: No delay                                                                             |  |  |  |  |  |  |  |
|           |           | Delay time = $(1/f_{LSI}) \times (0xFF - POR\_DELAY)$ .                                    |  |  |  |  |  |  |  |
| 15        | Reserved  | Reserved, the reset value must be maintained                                               |  |  |  |  |  |  |  |
| 14        | LVRRSTEN  | LVR reset enable                                                                           |  |  |  |  |  |  |  |
|           |           | 0: Enables LVR reset                                                                       |  |  |  |  |  |  |  |
|           |           | 1: Disables LVR reset                                                                      |  |  |  |  |  |  |  |
| 13        | LVRFILEN  | LVR filter enable                                                                          |  |  |  |  |  |  |  |
|           |           | 0: Enables LVR filter                                                                      |  |  |  |  |  |  |  |
|           |           | 1: Disables LVR filter                                                                     |  |  |  |  |  |  |  |
| 12        | LVREN     | LVR enable                                                                                 |  |  |  |  |  |  |  |
|           |           | 0: Enables LVR                                                                             |  |  |  |  |  |  |  |
|           |           | 1: Disables LVR                                                                            |  |  |  |  |  |  |  |
| 11:8      | LVRLS     | LVR level select.                                                                          |  |  |  |  |  |  |  |
|           |           | Value = $0x0F - LVRLS$                                                                     |  |  |  |  |  |  |  |
|           |           | Value Voltage                                                                              |  |  |  |  |  |  |  |
|           |           | 0000 1.8v                                                                                  |  |  |  |  |  |  |  |
|           |           | 0001 2.0v                                                                                  |  |  |  |  |  |  |  |
|           |           | 0010 2.2v                                                                                  |  |  |  |  |  |  |  |
|           |           | 0011 2.4v                                                                                  |  |  |  |  |  |  |  |



| Bit field | Name   | Description                             |           |       |
|-----------|--------|-----------------------------------------|-----------|-------|
|           |        | 0100                                    | 2.6v      |       |
|           |        | 0101                                    | 2.8v      |       |
|           |        | 0110                                    | 3.0v      |       |
|           |        | 0111                                    | 3.2v      |       |
|           |        | 1000                                    | 3.4v      |       |
|           |        | 1001                                    | 3.6v      |       |
|           |        | 1010                                    | 3.8v      |       |
|           |        | 1011                                    | 4.0v      |       |
|           |        | 1100                                    | 4.2v      |       |
|           |        | 1101                                    | 4.4v      |       |
|           |        | 1110                                    | 4.6v      |       |
|           |        | 1111                                    | 4.8v      |       |
| 7:0       | LVRCNT | LVR filter control count v              | alue      |       |
|           |        | 0x00: Maximum filtering                 | width     |       |
|           |        |                                         |           |       |
|           |        | 0xFF: Not filtered                      |           |       |
|           |        | Filter width = $(1/f_{LSI}) \times (0)$ | xFF - LVR | CNT). |

### 2.2.3.10 VTOR register (FLASH\_VTOR)

Address offset: 0x24



| Bit field | Name       | Description                                                                                    |
|-----------|------------|------------------------------------------------------------------------------------------------|
| 31        | VTOR_EN    | VTOR enable                                                                                    |
|           |            | 0: Enables VTOR                                                                                |
|           |            | 1: Disables VTOR                                                                               |
| 30:0      | VTOR_VALUE | Used for interrupt vector remapping to store the first address of the interrupt vector table   |
|           |            | These bits are valid when $VTOR\_EN = 1$ .                                                     |
|           |            | If the first address of the interrupt vector table needs to be remapped to the 0x08000C00, the |
|           |            | VTOR_VALUE is configured to 0x08000C00.                                                        |



# **3** Power control (PWR)

## 3.1 General description

The working voltage ( $V_{DD}$ ) of N32G003 is 2V~5.5V. It mainly has two power domains: analog/digital power supplies. Please refer to Figure 3-1 Power block diagram. As the power control unit of the SOC, PWR's main function is to control N32G003 to enter/exit different power modes. The N32G003 supports RUN, STOP and PD modes.

## 3.1.1 **Power supply**

The functions of different power domains are described below, and the digital part of the power domain is described in the following sections of this document. Refer to Figure 3-1 for power block diagram.

- V<sub>DD</sub>: The voltage input range is 2V~5.5V. It mainly provides power for PMU, HSI, etc.
- V<sub>DDD</sub>: The voltage regulator provides power for CPU, AHB, APB, SRAM, FLASH and most digital peripherals.

The embedded voltage regulator is used to power the internal digital module. The voltage regulator has three modes: normal mode, low power mode and power down mode.

■ Normal mode (MR)

1.5V output (typical), mainly used in RUN mode.

■ Low-power mode (LPR)

Mainly used in STOP mode. In STOP mode, low-power consumption mode output voltage (1.5V/1.2V) can be configured for lower current consumption. The default output is 1.5V, and the V<sub>DDD</sub> PDR trigger voltage is 1.2V. When PWR\_CTRL5.STPMRSEL[1:0] = '01', output voltage 1.5V, PWR\_CTRL.PDRS[1:0] must be configured for '11' (V<sub>DDD</sub> PDR trigger voltage 1.2V); when PWR\_CTRL5.STPMRSEL[1:0] = '11', output voltage 1.2V, PWR\_CTRL.PDRS[1:0] must be configured as '10' (V<sub>DDD</sub> PDR trigger voltage 1.0V).

■ Power-down mode

Voltage regulator off, mainly used in PD mode.





#### Figure 3-1 Power supply diagram



### 3.1.2 **Power supply supervisor**

### 3.1.2.1 Power on reset (POR) / power down reset (PDR)

N32G003 has an integrated power-on reset (POR) and power-down reset (PDR) circuits, which can work at a minimum voltage of 2V and requires no external reset circuit. When  $V_{DD}$  is lower than the specified threshold ( $V_{POR/PDR}$ ), N32G003 will remain in reset state.

For more information about the reset threshold of the switching power supply, please refer to the electrical characteristics section of the relevant data sheet.







### 3.1.2.2 Programmable voltage detector (PVD)

PVD is used to detect  $V_{DD}$  voltage level. The threshold of PVD is controlled by PWR\_CTRL.PLS [3:0]. PVD can be enabled/disabled by PWR\_CTRL.PVDEN bit.

PWR\_CTRLSTS.PVDO indicates whether  $V_{DD}$  is higher or lower than PVD threshold. This event also goes to EXTI line 18. If the EXTI register is enabled, an interrupt can be generated. When  $V_{DD}$  is lower than PVD threshold or when  $V_{DD}$  is higher than PVD threshold, PVD output interrupt can be generated according to the rising/falling edge configuration of EXTI line 18. For example, interrupt service routines can perform emergency shutdown.





### 3.1.2.3 Low voltage reset (LVR)

LVR is used to detect  $V_{DD}$  voltage level. The threshold of LVR is controlled by PWR\_CTRL2.LVRLS [3:0]. LVR can be enabled/disabled by PWR\_CTRL2.LVREN bit.



 $PWR\_CTRL2.LVRO$  indicates whether  $V_{DD}$  is higher or lower than LVR threshold. This event also goes to system reset.



Figure 3-4 LVR threshold diagram

## **3.2** Power modes

N32G003 has 3 power modes: RUN, STOP, and PD. Different modes have different performance and power consumption. Please refer to the following Table for N32G003 power modes:

| Mode | Condition                                           | Enter                                     | Exit                  |
|------|-----------------------------------------------------|-------------------------------------------|-----------------------|
| RUN  | CPU running.                                        | Power-on, system reset, low power         | Entering STOP or PD   |
| KUN  | Peripheral running depending on configuration.      | wake-up.                                  | modes.                |
|      | CPU deep sleep mode.                                |                                           |                       |
|      | The peripheral clock is turned off, and the voltage |                                           |                       |
|      | regulator is still running in a low-power mode.     |                                           |                       |
|      | HSI is turned off.                                  |                                           |                       |
|      | LSI switch can be configured.                       | WFI/WFE:                                  |                       |
|      | All GPIO states are kept, and all SRAM and          | 1) SCB_SCR.SLEEPDEEP = 1, No              | Any interrupt wake-up |
| STOP | registers keep data.                                | interrupt (for WFI) or event (for WFE) is | event by EXTI, NRST,  |
|      | All IO, PVD can be used to wake up the CPU. Or      | pending.                                  | IWDG.                 |
|      | other peripherals (TIM6) can be configured to       | 2) PWR_CTRL.PDSTP = 0                     |                       |
|      | wake up.                                            |                                           |                       |
|      | After waking up, the HSI is turned on, and the      |                                           |                       |
|      | code starts from where it was suspended.            |                                           |                       |
|      | Flash enters deep sleep mode.                       |                                           |                       |
|      | The main voltage regulator is turned off, and the   | WFI/WFE:                                  | WKUP0/1 rising or     |
| PD   | HSI/LSI is turned off.                              | 1) SCB_SCR.SLEEPDEEP = 1, No              | falling edge can be   |
|      | NRST and PA1_WKUP0/ PA2_WKUP1 two                   | interrupt (for WFI) or event (for WFE) is | configured, NRST      |

Table 3-1 Power modes



| Mode | Condition                                                  | Enter                 | Exit   |
|------|------------------------------------------------------------|-----------------------|--------|
|      | wake-up IO to the wake-up circuit in the $V_{\rm DD}$ area | pending.              | reset. |
|      | are used for PD wake-up.                                   | 2) PWR_CTRL.PDSTP = 1 |        |
|      | Most of the IO ports are in a high-Z state.                |                       |        |

Note:

1. STOP mode, after waking up, the code can continue to run from the stop position.

The running enable conditions of different modules in different power consumption modes are shown in the following

table:

|               |            | S      | top mode             | Power Down mode |                      |  |  |  |  |
|---------------|------------|--------|----------------------|-----------------|----------------------|--|--|--|--|
| Peripheral    | Run/Active | Status | Wakeup<br>capability | Status          | Wakeup<br>capability |  |  |  |  |
| Cortex-M0     | Y          | -      | -                    | -               | -                    |  |  |  |  |
| MR            | Y          | -      | -                    | -               | -                    |  |  |  |  |
| LPR           | Y          | Y      | -                    | -               | -                    |  |  |  |  |
| POR_VDD       | Y          | Y      | Y                    | -               | -                    |  |  |  |  |
| PDR_VDD       | Y          | Y      | Y                    | -               | -                    |  |  |  |  |
| POR_VDDD      | Y          | Y      | -                    | -               | -                    |  |  |  |  |
| PDR_VDDD      | Y          | 0      | 0                    | -               | -                    |  |  |  |  |
| PVD           | 0          | 0      | 0                    | -               | -                    |  |  |  |  |
| LVR           | 0          | 0      | 0                    | -               | -                    |  |  |  |  |
| FLASH         | Y          | DSTB   | -                    | -               | -                    |  |  |  |  |
| SRAM3KB       | Y          | Y      | -                    | -               | -                    |  |  |  |  |
| HSI           | Y          | -      | -                    | -               | -                    |  |  |  |  |
| LSI           | Y          | 0      | -                    | -               | -                    |  |  |  |  |
| UART1/2       | 0          | -      | -                    | -               | -                    |  |  |  |  |
| I2C           | 0          | -      | -                    | -               | -                    |  |  |  |  |
| SPI           | 0          | -      | -                    | -               | -                    |  |  |  |  |
| ADC           | 0          | -      | -                    | -               | -                    |  |  |  |  |
| TIM1/3        | 0          | -      | -                    | -               | -                    |  |  |  |  |
| TIM6          | 0          | 0      | 0                    | -               | -                    |  |  |  |  |
| IWDG          | 0          | 0      | 0                    | -               | -                    |  |  |  |  |
| COMP          | 0          | -      | _                    | -               | -                    |  |  |  |  |
| SysTick timer | 0          | -      | -                    | -               | -                    |  |  |  |  |
| CRC           | 0          | -      | -                    | -               | -                    |  |  |  |  |
| GPIOs         | 0          | 0      | 0                    | -               | 2 pins               |  |  |  |  |

#### Table 3-2 Peripheral running status

Note:

1. *Y:* enable, *O:* optional (Disabled by default and enabled by software configuration), -: disable, DSTB: deep-standby.



2. The pins that can wake up from PD are PA1 (WKUP0), PA2 (WKUP1), NRST.

## 3.2.1 STOP mode

STOP mode is based on Cortex<sup>®</sup>-M0 deep sleep mode, combined with peripheral clock gating. Voltage regulator operates in low power mode. The output voltage (1.5V/1.2V) output is configurable. In STOP mode, disable as HSI. But the contents of SRAM and all registers are saved. Flash automatically enter deep sleep mode. In STOP mode, all I/O pins remain in the same state as in run mode.

#### 3.2.1.1 Enter STOP mode

When entering STOP mode, need set  $SCB\_SCR.SLEEPDEEP = 1$  and  $PWR\_CTRL.PDSTP = 0$ .

If a FLASH operation is in progress, the time to enter STOP mode will be delayed until the memory access is completed.

If the access to the APB area is in progress, the time to enter the STOP mode will be delayed until the APB access is completed.

In STOP mode, the following peripherals are available:

- Independent Watchdog (IWDG): The independent watchdog will be activated when its related register is written by software or by hardware operation. Once enabled, it will keep counting until a reset is generated.
- IO and TIM6/PVD peripherals can wake up.
- Internal RC oscillator (LSI RC): It can be turned on by the PWR\_CTRL3.LSIEN.

ADC should be disabled when entering STOP mode to avoid unnecessary power consumption.

#### 3.2.1.2 Exit STOP mode

When an interrupt or wake-up event wakes up STOP mode, the HSI RC oscillator is selected as the system clock, codes resumed from suspended location. Since the voltage regulator is in low power mode, it takes extra start-up time to wakes up from STOP mode. In addition, shorten the FLASH wake up time by set PWR\_CTRL4.FLHWKUP = 1 before enter STOP.

## 3.2.2 **PD mode**

PD (Power Down) mode is based on Cortex®-M0 deep sleep mode, which can achieve lower power consumption. In this mode, the CPU, all peripherals, voltage regulator, HSI/LSI clock sources and all digital power supplies (V<sub>DDD</sub>) are turned off, All GPIO pins are in a high-impedance state, where NRST/PA1\_WKUP0/PA2\_WKUP1 can be used to wake up PD mode.

#### 3.2.2.1 Enter PD mode

When entering the PD mode, user needs to set SCB\_SCR.SLEEPDEEP = 1 and PWR\_CTRL.PDSTP = 1.

If a FLASH operation is in progress, entering PD mode will be delayed until memory access is complete.

If the access to the APB area is in progress, entering PD mode will be delayed until the APB access is complete.



#### 3.2.2.2 Exit PD mode

When external reset (NRST pin) occurs, WKUP pin rising edge or falling edge events occur, MCU will exit PD mode. All registers are reset when wake up from PD mode.

After waking up from PD mode, code execution is equivalent to execution after reset (read reset vector, etc.).

## 3.3 Debug mode

By default, if application puts the MCU in STOP or PD mode while using the debugging feature, the debugging connection will be lost. Because the Cortex®-M0 core loses its clock.

However, by setting some configuration bits in the DBG\_CTRL register, the software can be debugged even when the STOP and PD mode are used. If these register bits are configured, the voltage regulator and HSI will not be disabled or turned off.

### 3.3.1 Low power mode debug mode support

When debugging in low power mode, you need to ensure that the FCLK of the kernel is enabled to provide the necessary clock for kernel debugging. The software needs to configure the DBG\_CTRL.STOP or DBG\_CTRL.PD bit in the debug control register, start the internal RC oscillator and provide the clock for FCLK. For specific features and functions, see the description of DBG\_CTRL.PD and DBG\_CTRL.STOP bit fields in the DBG\_CTRL register in Section 3.4.9.

### 3.3.2 **Peripheral debug support**

In addition to supporting debug in low power mode, it also supports some peripherals to stop working in debug state (TIM1, TIM3, TIM6, IWDG). When the corresponding bit of the peripheral control bit in the DBGCTRL register is set, the corresponding peripheral enters the debugging state after the kernel stops. For specific operations and features, please refer to the description of the other bit fields of the DBG\_CTRL register in Section 3.4.9.

## **3.4 PWR registers**

### 3.4.1 **PWR register overview**

| Offset | Register    | 31 | 30 | 29    | 28 | 27 | 26      | 25       | 24 | 23 | 22 | 21    | 20    | 19  | 18 | 17 | 16 | 15 | 14    | 13 | 12 | 11      | 10        | 9         | 8              | 7   | 6     | 5      | 4     | 3         | 2        | 1      | 0         |
|--------|-------------|----|----|-------|----|----|---------|----------|----|----|----|-------|-------|-----|----|----|----|----|-------|----|----|---------|-----------|-----------|----------------|-----|-------|--------|-------|-----------|----------|--------|-----------|
| 0x00   | PWR_CTRL    |    | R  | eserv | ed |    | PVDITEN | PVDFILEN |    |    | Р  | VDCI  | NT[7: | :0] |    |    |    | R  | eserv | ed |    | NRSTPOL | ווייזאמתמ | FDK3[1:0] |                | PLS | [3:0] |        | PVDEN | CLRDBGPDF | CLRWKUPF | PDSTP  | IWDGRSTEN |
|        | Reset value |    |    |       |    |    | 0       | 0        | 0  | 0  | 0  | 0     | 0     | 0   | 0  | 0  |    |    |       |    |    | 0       | 1         | 1         | 0              | 0   | 0     | 0      | 0     | 0         | 0        | 0      | 1         |
| 0x04   | PWR_CTRLSTS |    |    |       |    |    |         |          |    |    | R  | eserv | ed    |     |    |    |    |    |       |    |    |         | WKUPPOL   | WKUPIEN   | <b>WKUP0EN</b> |     | R     | eserve | ed    |           | PVDO     | DBGPDF | WKUPF     |
|        | Reset value |    |    |       |    |    |         |          |    |    |    |       |       |     |    |    |    |    |       |    |    |         | 1         | 0         | 0              |     |       |        |       |           | 0        | 0      | 0         |

#### Table 3-3 PWR register overview



| Offset | Register    | 31 30 29 28 27 26 25 2 | 23 22 21 20 19 18 17 16                            | 15 14 | 13 12 11        | 10  | 9 8                | 7       | 6       | 5       | 4 3      | 2                 | 1         | 0        |
|--------|-------------|------------------------|----------------------------------------------------|-------|-----------------|-----|--------------------|---------|---------|---------|----------|-------------------|-----------|----------|
| 0x08   | PWR_CTRL2   | LVRKEY[7:0]            | Reserved 1 King King King King King King King King |       |                 |     |                    |         |         |         |          |                   |           |          |
|        | Reset value | 0 0 0 0 0 0 0 0        |                                                    | 0 0   | 0 0 0           | 1   | 0 0                | 0       | 0       | 0       | 0 0      | 0                 | 0         | 0        |
| 0x14   | PWR_CTRL3   |                        | Reserved                                           |       | LSISTPO<br>[2:] | CNT | PDRSEL<br>Reserved | LSIEN   | HSISEL  | HSIPWR  |          | Reserved          |           |          |
|        | Reset value |                        |                                                    |       | 0 1             | 1   | 1                  | 1       | 0       | 1       |          |                   |           |          |
| 0x20   | PWR_CTRL4   |                        | Reserved                                           |       |                 |     |                    |         |         |         |          | RUNF              | STBFLH    | FLHWKUP  |
|        | Reset value |                        |                                                    |       |                 |     |                    |         |         |         |          | 0                 | 0         | 0        |
| 0x24   | PWR_CTRL5   |                        | Reserved                                           |       |                 |     |                    |         |         |         |          | STPMRSE<br>L[1:0] | Doctoriod | Keserved |
|        | Reset value |                        |                                                    |       |                 |     |                    |         |         |         | C        | ) 1               |           |          |
| 0x28   | PWR_CTRL6   |                        | Reserved IS IN                                     |       |                 |     |                    |         |         |         |          | STPMRE<br>N[1:0]  | Docemend  | Keserved |
|        | Reset value |                        |                                                    |       |                 |     |                    |         |         |         | C        | 0 0               |           |          |
| 0x30   | DBG_CTRL    |                        | Reserved                                           |       |                 |     | TIM6STP            | TIM3STP | TIM1STP | IWDGSTP | Reserved | DD                | STOP      | Reserved |
|        | Reset value |                        |                                                    |       |                 |     | 0                  | 0       | 0       | 0       |          | 0                 | 0         |          |

# 3.4.2 **Power control register (PWR\_CTRL)**

#### Address offset: 0x00

| 31 |      |          |    | 27          | 26          | 25           | 24 |      |       |        |         |               |              | 17    | 16            |
|----|------|----------|----|-------------|-------------|--------------|----|------|-------|--------|---------|---------------|--------------|-------|---------------|
|    |      | Reserved | 1  | 1           | PVD<br>ITEN | PVD<br>FILEN |    |      |       | PVDC   | NT[7:0] |               |              |       | Reserved      |
| 15 |      |          | 12 | 11          | rw<br>10    | rw<br>9      | 8  |      |       | r<br>5 | w 4     | 3             | 2            | 1     | 0             |
|    | Rese | rved     |    | NRST<br>POL | PDR         | S[1:0]       |    | PLS[ | [3:0] |        | PVDEN   | CLR<br>DBGPDF | CLR<br>WKUPF | PDSTP | IWDG<br>RSTEN |
|    |      |          |    | rw          | r           | w            |    | rv   | v     |        | rw      | rc_w1         | rc_w1        | rw    | rw            |

| Bit field | Name     | Description                                   |
|-----------|----------|-----------------------------------------------|
| 31:27     | Reserved | Reserved, the reset value must be maintained. |
| 26        | PVDITEN  | PVD interrupt enable.                         |
|           |          | 0: PVD interrupt disabled.                    |
|           |          | 1: PVD interrupt enabled.                     |
| 25        | PVDFILEN | PVD filter enable.                            |
|           |          | 0: PVD filter disabled.                       |
|           |          | 1: PVD filter enabled.                        |
| 24:17     | PVDCNT   | PVD filter control counter value.             |
|           |          | 0x00: Not filtered                            |



| Bit field | Name      | Description                                                                                 |  |  |  |  |  |  |
|-----------|-----------|---------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|           |           |                                                                                             |  |  |  |  |  |  |
|           |           | 0xFF: Maximum filtering width                                                               |  |  |  |  |  |  |
|           |           | Filter width = $(1/f_{LSI}) \times PVDCNT$ .                                                |  |  |  |  |  |  |
| 16:12     | Reserved  | Reserved, the reset value must be maintained.                                               |  |  |  |  |  |  |
| 11        | NRSTPOL   | NRST polarity select.                                                                       |  |  |  |  |  |  |
|           |           | 0: The falling edge of NRST pin.                                                            |  |  |  |  |  |  |
|           |           | 1: The rising edge of NRST pin.                                                             |  |  |  |  |  |  |
| 10:9      | PDRS[1:0] | Adjust the VDDD PDR trigger level in STOP mode.                                             |  |  |  |  |  |  |
|           |           | 00: Reserved.                                                                               |  |  |  |  |  |  |
|           |           | 01: Reserved.                                                                               |  |  |  |  |  |  |
|           |           | 10: V <sub>DDD</sub> PDR trigger level is 1.0V.                                             |  |  |  |  |  |  |
|           |           | 11: V <sub>DDD</sub> PDR trigger level is 1.2V.                                             |  |  |  |  |  |  |
|           |           | Only $V_{DDD}$ POR/PDR can reset this bit, if $V_{PDRS} < V_{STOP}$ values, the PDR will be |  |  |  |  |  |  |
|           |           | triggered.                                                                                  |  |  |  |  |  |  |
| 8:5       | PLS[3:0]  | PVD level selection.                                                                        |  |  |  |  |  |  |
|           |           | PVD threshold is controlled below:                                                          |  |  |  |  |  |  |
|           |           | PWR_CTRL.PLS Voltage                                                                        |  |  |  |  |  |  |
|           |           | 0000 1.8v                                                                                   |  |  |  |  |  |  |
|           |           | 0001 2.0v                                                                                   |  |  |  |  |  |  |
|           |           | 0010 2.2v                                                                                   |  |  |  |  |  |  |
|           |           | 0011 2.4v                                                                                   |  |  |  |  |  |  |
|           |           | 0100 2.6v                                                                                   |  |  |  |  |  |  |
|           |           | 0101 2.8v                                                                                   |  |  |  |  |  |  |
|           |           | 0110 3.0v                                                                                   |  |  |  |  |  |  |
|           |           | 0111 3.2v                                                                                   |  |  |  |  |  |  |
|           |           | 1000 3.4v                                                                                   |  |  |  |  |  |  |
|           |           | 1001 3.6v                                                                                   |  |  |  |  |  |  |
|           |           | 1010 3.8v                                                                                   |  |  |  |  |  |  |
|           |           | 1011 4.0v                                                                                   |  |  |  |  |  |  |
|           |           | 1100 4.2v                                                                                   |  |  |  |  |  |  |
|           |           | 1101 4.4v                                                                                   |  |  |  |  |  |  |
|           |           | 1110 4.6v                                                                                   |  |  |  |  |  |  |
|           |           | 1111 4.8v                                                                                   |  |  |  |  |  |  |
| 4         | PVDEN     | The Power voltage detector (PVD) enable.                                                    |  |  |  |  |  |  |
|           |           | 0: PVD disabled.                                                                            |  |  |  |  |  |  |
|           |           | 1: PVD enabled.                                                                             |  |  |  |  |  |  |
| 3         | CLRDBGPDF | The software writes a '1' to this bit to clear the DBGPDF status bit. Always read as        |  |  |  |  |  |  |
| -         |           | 0.                                                                                          |  |  |  |  |  |  |
|           |           |                                                                                             |  |  |  |  |  |  |
|           |           |                                                                                             |  |  |  |  |  |  |
|           |           | 0: Invalid.<br>1: Clear the DBGPDF status bit.                                              |  |  |  |  |  |  |



| Bit field | Name      | Description                                                    |
|-----------|-----------|----------------------------------------------------------------|
| 2         | CLRWKUPF  | Clear the wake-up bit.                                         |
|           |           | Always read as 0.                                              |
|           |           | 0: Invalid.                                                    |
|           |           | 1: Clear WKUPF (write) after 2 system clock cycles.            |
| 1         | PDSTP     | Enter STOP/PD mode selection.                                  |
|           |           | 0: CPU output DEEPSLEEP is '1', and the chip enters STOP mode. |
|           |           | 1: CPU output DEEPSLEEP is '1', and the chip enters PD mode.   |
| 0         | IWDGRSTEN | IWDG reset enable control.                                     |
|           |           | 0: IWDG reset request will not generate a system reset.        |
|           |           | 1: IWDG reset request will generate a system reset.            |

# 3.4.3 **Power control status register (PWR\_CTRLSTS)**

Address offset: 0x04

| 31 |   |          |   |    |             |             |             |      |   |          |   |   |      |        | 16    |
|----|---|----------|---|----|-------------|-------------|-------------|------|---|----------|---|---|------|--------|-------|
|    | 1 | 1        | 1 |    | 1           | 1           | Rese        | rved | 1 | 1        | 1 |   | 1    |        |       |
| 15 |   |          |   | 11 | 10          | 9           | 8           | 7    |   |          |   | 3 | 2    | 1      | 0     |
|    | 1 | Reserved | 1 |    | WKUP<br>POL | WKUP1<br>EN | WKUP0<br>EN |      |   | Reserved | 1 |   | PVDO | DBGPDF | WKUPF |
|    |   |          |   |    | rw          | rw          | rw          |      |   |          |   |   | r    | r      | r     |

| Bit field | Name     | Description                                                                           |
|-----------|----------|---------------------------------------------------------------------------------------|
| 31:11     | Reserved | Reserved, the reset value must be maintained.                                         |
| 10        | WKUPPOL  | Wakeup polarity for PA1/PA2. To wakeup PD mode by using rising edge or falling edge.  |
|           |          | Make sure disable wakeup enable before changing polarity value.                       |
|           |          | 0: Falling edge.                                                                      |
|           |          | 1: Rising edge.                                                                       |
| 9         | WKUP1EN  | WKUP pin PA2 enable control.                                                          |
|           |          | 0: WKUP pin is used for general purpose I/O. An event on the WKUP pin does not wakeup |
|           |          | the device from PD mode.                                                              |
|           |          | 1: WKUP pin is used for wakeup from PD mode.                                          |
|           |          | Note: This bit is reset by V_DDD POR Reset only.                                      |
| 8         | WKUP0EN  | WKUP pin PA1 enable control.                                                          |
|           |          | 0: WKUP pin is used for general purpose I/O. An event on the WKUP pin does not wakeup |
|           |          | the device from PD mode.                                                              |
|           |          | 1: WKUP pin is used for wakeup from PD mode.                                          |
|           |          | Note: This bit is reset by VDDD POR Reset only.                                       |
| 7:3       | Reserved | Reserved, the reset value must be maintained.                                         |
| 2         | PVDO     | PVD output.                                                                           |
|           |          | It is valid only if PWR_CTRL.PVDEN = 1.                                               |
|           |          | 0: V <sub>DD</sub> is higher than the PVD threshold selected with PWR_CTRL.PLS [3:0]. |



| Bit field | Name   | Description                                                                   |
|-----------|--------|-------------------------------------------------------------------------------|
|           |        | 1: $V_{DD}$ is lower than the PVD threshold selected with PWR_CTRL.PLS [3:0]. |
| 1         | DBGPDF | DBGPD mode status bit.                                                        |
|           |        | When entering DBGPD mode, hardware sets this bit to '1'.                      |
|           |        | Hardware clears this bit when software sets PWR_CTRL.CLRDBGPDF = 1.           |
|           |        | Only V <sub>DDD</sub> POR/PDR can reset this bit.                             |
|           |        | 0: Chip never entered DBGPD mode.                                             |
|           |        | 1: Chip has entered DBGPD mode.                                               |
| 0         | WKUPF  | DBGPD mode wake-up status bit.                                                |
|           |        | This bit is set by hardware after WKUP pin wakes up DBGPD mode.               |
|           |        | Hardware clears this bit when software sets PWR_CTRL.CLRWKUPF = 1.            |
|           |        | Only V <sub>DDD</sub> POR/PDR can reset this bit.                             |
|           |        | 0: No wakeup event occurred.                                                  |
|           |        | 1: A wakeup event was received from the WKUP pin.                             |

# 3.4.4 **Power control register 2 (PWR\_CTRL2)**

Address offset: 0x08

Reset value: 0x0000 0400

This register is write-protected. Each time the software writes to this register, it must first write the key 0xA5000000 (unlocked) to this register.

| 31   |    |      |        |              |       |              | 24           | 23 |   | <br>   |        |   |   | 16 |
|------|----|------|--------|--------------|-------|--------------|--------------|----|---|--------|--------|---|---|----|
|      |    |      | LVRK   | '<br>EY[7:0] |       |              |              |    |   | Reser  | ved    |   |   |    |
| 15   | 14 |      | 1      | rw 11        | 10    | 9            | 8            | 7  |   | <br>II |        |   | 1 | 0  |
| LVRO |    | LVRL | S[3:0] | 1            | LVREN | LVR<br>RSTEN | LVR<br>FILEN |    | 1 | LVRCN  | T[7:0] | 1 |   |    |
| r    |    | r    | w      |              | rw    | rw           | rw           |    |   | rw     | 7      |   |   |    |

| Bit field | Name       | Description                                                                            |
|-----------|------------|----------------------------------------------------------------------------------------|
| 31:24     | LVRKEY     | LVR key.                                                                               |
| 23:16     | Reserved   | Reserved, the reset value must be maintained.                                          |
| 15        | LVRO       | LVR output.                                                                            |
|           |            | It is valid only if PWR_CTRL2.LVREN = 1.                                               |
|           |            | 0: V <sub>DD</sub> is higher than the LVR threshold selected by PWR_CTRL2.LVRLS [3:0]. |
|           |            | 1: V <sub>DD</sub> is lower than the LVR threshold selected by PWR_CTRL2.LVRLS [3:0].  |
| 14:11     | LVRLS[3:0] | LVR level selection.                                                                   |
|           |            | LVR threshold is controlled below:                                                     |
|           |            | PWR_CTRL2.LVRLS Voltage                                                                |
|           |            | 0000 1.8v                                                                              |
|           |            | 0001 2.0v                                                                              |
|           |            | 0010 2.2v                                                                              |
|           |            | 0011 2.4v                                                                              |



| Bit field | Name     | Description                                  |
|-----------|----------|----------------------------------------------|
|           |          | 0100 2.6v                                    |
|           |          | 0101 2.8v                                    |
|           |          | 0110 3.0v                                    |
|           |          | 0111 3.2v                                    |
|           |          | 1000 3.4v                                    |
|           |          | 1001 3.6v                                    |
|           |          | 1010 3.8v                                    |
|           |          | 1011 4.0v                                    |
|           |          | 1100 4.2v                                    |
|           |          | 1101 4.4v                                    |
|           |          | 1110 4.6v                                    |
|           |          | 1111 4.8v                                    |
| 10        | LVREN    | LVR enable.                                  |
|           |          | 0: LVR disabled.                             |
|           |          | 1: LVR enabled.                              |
| 9         | LVRRSTEN | LVR reset Enable.                            |
|           |          | 0: LVR reset disabled.                       |
|           |          | 1: LVR reset enabled.                        |
| 8         | LVRFILEN | LVR filter Enable.                           |
|           |          | 0: LVR filter disabled.                      |
|           |          | 1: LVR filter enabled.                       |
| 7:0       | LVRCNT   | LVR filter control count value.              |
|           |          | 0x00: Not filtered                           |
|           |          |                                              |
|           |          | 0xFF: Maximum filtering width                |
|           |          | Filter width = $(1/f_{LSI}) \times LVRCNT$ . |

# 3.4.5 **Power control register 3 (PWR\_CTRL3)**

Address offset: 0x14

Reset value: 0x0000 0EAF



| Bit field | Name      | Description                                                                         |  |  |  |
|-----------|-----------|-------------------------------------------------------------------------------------|--|--|--|
| 31:13     | Reserved  | Reserved, the reset value must be maintained.                                       |  |  |  |
| 12:10     | LSISTPCNT | After exit STOP, user can delay starting the LSI to stabilize the LSI. The delay is |  |  |  |
|           |           | determined by the LSISTPCNT configuration.                                          |  |  |  |

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| Bit field | Name     | Description                                                                                     |
|-----------|----------|-------------------------------------------------------------------------------------------------|
|           |          | Note: These bits are used with PWR_CTRL3.LSIEN.                                                 |
| 9         | PDRSEL   | 0: V <sub>DDD</sub> PDR selection signal is pulled high by default. In this case, PWR_CTRL.PDRS |
|           |          | [1:0] == '11'.                                                                                  |
|           |          | 1: V <sub>DDD</sub> PDR selection is controlled by PWR.                                         |
| 8         | Reserved | Reserved, the reset value must be maintained.                                                   |
| 7         | LSIEN    | Control PWR to enable LSI.                                                                      |
|           |          | 0: PWR (always included in STOP mode) request to enable LSI.                                    |
|           |          | 1: After entering STOP, PWR no longer requests to enable LSI.                                   |
| 6         | HSISEL   | HSI frequency trim select.                                                                      |
|           |          | 0: HSI 48M trim.                                                                                |
|           |          | 1: HSI 40M trim.                                                                                |
| 5         | HSIPWR   | HSI controller select                                                                           |
|           |          | 0: HSI is not controlled by PWR.                                                                |
|           |          | 1: HSI is controlled by PWR.                                                                    |
|           |          | Note: After this bit is enabled, you can configure PWR_CTRL3.HSISEL                             |
| 4:0       | Reserved | Reserved, the reset value must be maintained.                                                   |

# 3.4.6 **Power control register 4 (PWR\_CTRL4)**

Address offset: 0x20

Reset value: 0x0000 0000

This register is write-protected. Each time the software writes to this register, it must first write the key  $0x0175_3603$  (unlocked) to this register.

| 31 |   |   | 1 |   |   |          | 1    |       |   |   | 1 |   |      |        | 16          |
|----|---|---|---|---|---|----------|------|-------|---|---|---|---|------|--------|-------------|
|    | 1 | I | I | I |   | 1        | Rese | erved | I | 1 |   | I | I    |        | '           |
|    | 1 | 1 | 1 | 1 | 1 | 1        | 1    | 1     |   | 1 | 1 | 1 |      | 1      | L]          |
| 15 |   |   |   |   | _ |          |      |       |   |   |   | 3 | 2    | 1      | 0           |
|    |   | 1 |   | 1 |   | Reserved | 1    |       |   |   | 1 | 1 | RUNF | STBFLH | FLH<br>WKUP |
|    |   | • |   |   |   |          |      |       |   |   |   |   |      |        | ·           |

| Bit field | Name     | Description                                                                               |
|-----------|----------|-------------------------------------------------------------------------------------------|
| 31:3      | Reserved | Reserved, the reset value must be maintained.                                             |
| 2         | RUNF     | RUN mode flag.                                                                            |
|           |          | 0: System not in RUN mode.                                                                |
|           |          | 1: System in RUN mode.                                                                    |
| 1         | STBFLH   | Flash deep standby mode enable (configurable in RUN mode)                                 |
|           |          | This bit is set and reset by software, or reset by hardware in STOP and PD modes.         |
|           |          | 0: After the software clears this bit, Flash exit the deep standby mode and return to the |
|           |          | normal operating mode.                                                                    |
|           |          | 1: After the software set this bit to '1', the Flash enter deep standby mode.             |
| 0         | FLHWKUP  | Enable Flash fast wake-up.                                                                |



| Bit field | Name | Description                                                           |
|-----------|------|-----------------------------------------------------------------------|
|           |      | 0: When the chip exits from STOP mode, use Flash to wake up normally. |
|           |      | 1: When the chip exits from STOP mode, use Flash to wake up quickly.  |
|           |      | Note: Please refer to the data sheet for the wake-up time.            |

# 3.4.7 **Power control register 5 (PWR\_CTRL5)**

Address offset: 0x24

Reset value: 0x0000 0004

| 31 | - | - |   | <br> | -     |      |       | <br> |   |       | -        |      | 16    |
|----|---|---|---|------|-------|------|-------|------|---|-------|----------|------|-------|
|    |   |   | 1 |      |       | Rese | erved | 1    | 1 |       |          |      |       |
| 15 |   | • |   |      | •     |      |       |      | 4 | 3     | 2        | 1    | 0     |
|    |   |   |   | Rese | erved |      |       |      |   | STPMR | SEL[1:0] | Rese | erved |
|    |   |   |   |      |       |      |       |      |   | r     | w        |      |       |

| Bit field | Name          | Description                                                                                      |
|-----------|---------------|--------------------------------------------------------------------------------------------------|
| 31:4      | Reserved      | Reserved, the reset value must be maintained.                                                    |
| 3:2       | STPMRSEL[1:0] | After the chip enters STOP mode, V <sub>DDD</sub> output voltage is selected. Before configuring |
|           |               | this register bit, the software must first configure PWR_CTRL6.STPMREN = '11'.                   |
|           |               | 00: No used.                                                                                     |
|           |               | 01: V <sub>DDD</sub> output voltage 1.5V.                                                        |
|           |               | 10: Reserved.                                                                                    |
|           |               | 11: V <sub>DDD</sub> output voltage 1.2V.                                                        |
|           |               | This bit is reset by V <sub>DDD</sub> POR only.                                                  |
| 1:0       | Reserved      | Reserved, the reset value must be maintained.                                                    |

# 3.4.8 **Power control register 6 (PWR\_CTRL6)**

Address offset: 0x28



| Bit field | Name     | Description                                   |
|-----------|----------|-----------------------------------------------|
| 31:4      | Reserved | Reserved, the reset value must be maintained. |



| Bit field | Name         | Description                                                                  |
|-----------|--------------|------------------------------------------------------------------------------|
| 3:2       | STPMREN[1:0] | V <sub>DDD</sub> Output voltage selection enable.                            |
|           |              | 00: Enter STOP mode, V <sub>DDD</sub> Output voltage 1.5V.                   |
|           |              | 01/10: Reserved.                                                             |
|           |              | 11: Enter STOP mode, $V_{DDD}$ Output voltage control by PWR_CTRL5.STPMRSEL. |
|           |              | This bit is reset by $V_{DDD}$ POR only.                                     |
| 1:0       | Reserved     | Reserved, the reset value must be maintained.                                |

# 3.4.9 **Debug control register (DBG\_CTRL)**

Address offset: 0x30

Reset value: 0x0000 0000

Only  $V_{DDD}$  POR/PDR can reset this register. Only after the Debugger is connected, the software can write access to this register.



| Bit field | Name     | Description                                                               |
|-----------|----------|---------------------------------------------------------------------------|
| 31:9      | Reserved | Reserved, the reset value must be maintained.                             |
| 8         | TIM6STP  | The counter of TIM6 stops working when the kernel enters the debug state. |
|           |          | Set or cleared by software.                                               |
|           |          | 0: The counter of TIM6 still works normally.                              |
|           |          | 1: The counter of TIM6 stops working.                                     |
| 7         | TIM3STP  | The counter of TIM3 stops working when the kernel enters the debug state. |
|           |          | Set or cleared by software.                                               |
|           |          | 0: The counter of TIM3 still works normally.                              |
|           |          | 1: The counter of TIM3 stops working.                                     |
| 6         | TIM1STP  | The counter of TIM1 stops working when the kernel enters the debug state. |
|           |          | Set or cleared by software.                                               |
|           |          | 0: The counter of TIM1 still works normally.                              |
|           |          | 1: The counter of TIM1 stops working.                                     |
| 5         | IWDGSTP  | The counter of IWDG stops working when the kernel enters the debug state. |
|           |          | Set or cleared by software.                                               |
|           |          | 0: The counter of IWDG still works normally.                              |
|           |          | 1: The counter of IWDG stops working.                                     |
| 4:3       | Reserved | Reserved, the reset value must be maintained.                             |



| Bit field | Name     | Description                                                                           |
|-----------|----------|---------------------------------------------------------------------------------------|
| 2         | PD       | Debug PD mode control.                                                                |
|           |          | Set or cleared by software.                                                           |
|           |          | 0: (FCLK off, HCLK off) system enters PD mode, digital circuit part is unpowered.     |
|           |          | From a software point of view, exiting PD mode is the same as a power-on reset.       |
|           |          | 1: (FCLK on, HCLK on) system enters DBGPD mode, digital circuit part is powered,      |
|           |          | and FCLK clock is provided by the internal RC oscillator. In addition, the            |
|           |          | microcontroller exits DBGPD mode by generating a system reset, which is the same as a |
|           |          | system reset.                                                                         |
| 1         | STOP     | Debug STOP mode control.                                                              |
|           |          | Set or cleared by software.                                                           |
|           |          | 0: (FCLK off, HCLK off) system enters STOP mode, clock controller disables all clocks |
|           |          | (including HCLK and FCLK). When exiting STOP mode, the configuration of the clock     |
|           |          | is the same as after reset (Microcontroller is clocked by the 48MHz internal RC       |
|           |          | oscillator (HSI)).                                                                    |
|           |          | 1: (FCLK on, HCLK on) system enters DBGSTOP mode, FCLK clock is provided by           |
|           |          | the internal RC oscillator.                                                           |
| 0         | Reserved | Reserved, the reset value must be maintained.                                         |



# 4 Reset and clock control (RCC)

## 4.1 Reset Control Unit

N32G003 supports the following two types of reset:

- Power Reset
- System Reset

### 4.1.1 **Power reset**

A Power reset occurs in the following circumstances:

- Power-on/ Power-down reset (POR/PDR reset).
- When exiting PD mode.

A power reset sets all registers to their reset values.

### 4.1.2 System reset

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

- A low level on the NRST pin (external reset)
- Independent watchdog end of count condition (IWDG reset)
- Software reset (SW reset)
- Low power management reset
- EMC reset
- LVR reset

Except for the following registers, a system reset will reset all registers to their reset states:

- RCC\_CTRLSTS
- RCC\_EMCCTRL
- PWR\_CTRL.PDRS[1:0], PWR\_CTRL.NRSTPOL
- PWR\_CTRLSTS.WKUPF, PWR\_CTRLSTS.WKUP0EN, PWR\_CTRLSTS.WKUP1EN, PWR\_CTRLSTS. WKUPPOL
- PWR\_CTRL3.HSISEL
- DBG\_CTRL

The reset source can be identified by checking the reset flags in the Control/Status Register (RCC\_CTRLSTS).

#### 4.1.2.1 Software reset

A software reset can be generated by setting the SYSRESETREQ bit in Cortex®-M0 Application Interrupt and Reset



Control Register. Refer to Cortex<sup>®</sup>-M0 technical reference manual for further information.

#### 4.1.2.2 Low-power management reset

Low-power management reset can be generated by using the following methods:

- Low-power management reset generated when entering PD mode: This reset is enabled by resetting the nRST\_PD bit in User Option Bytes. In this case, whenever a PD mode entry sequence is successfully executed, the system is reset instead of entering PD mode.
- Low-power management reset generated when entering STOP modes: This reset is enabled by resetting the nRST\_STOP bit in User Option Bytes. In this case, whenever a STOP mode entry sequence is successfully executed, the system is reset instead of entering STOP modes.

The reset source will act on the NRST pin and remain low during reset. The reset entry vector is fixed at address 0x0000\_0004. For more details, see Table 6-1 Vector table.

The system reset signal provided to the chip is output on the NRST pin. The pulse generator guarantees a minimum reset pulse duration of 20µs for each reset source (external or internal). For external reset, the reset pulse is generated while the NRST pin is asserted low.

The Figure below shows the system reset generation circuit.



#### Figure 4-1 System reset generation



# 4.2 Clock control unit

The HSI oscillator clock source is used to drive the system clock (SYSCLK).

The 32KHz low-speed internal RC is used as a secondary clock source, which can be programmed to drive an independent watchdog (IWDG), TIM6 (for wake-up STOP mode).

The frequency of the AHB, APBdomains can be configured by the user through multiple prescalers. The maximum allowable frequency of the AHB domain, APB domain is 48MHz.

All peripheral clocks are derived from the system clock (SYSCLK) except in the following cases:

- ADC working clock source and ADC1M clock source are HSI
- By configuring RCC\_CFG2.TIM1CLKSEL, you can select one of the following two cases as the TIM1 working clock source:
  - ♦ APB clock (PCLK)
  - ♦ LSI clock
- By configuring RCC\_CFG2.TIM6CLKSEL, you can select one of the following two cases as the TIM1 working clock source:
  - ♦ APB clock (PCLK)
  - ♦ SYSCLK

When the timer clock source is PCLK, timer clock frequency is automatically set by hardware in the following 2 cases:

- $\diamond$  If the corresponding APB prescaler is 1, the timer clock frequency is the same as the APB frequency.
- $\diamond$  If the corresponding APB prescaler is not 1, the timer clock frequency is twice the APB frequency.
- IWDG clock source is LSI oscillator.
- Flash memory programming interface clock is always the HSI clock
- By configuring the SysTick control and status registers, you can select one of the following two cases as the SysTick clock source:
  - AHB clock (HCLK) divided by 8
  - ♦ AHB clock (HCLK)

FCLK is the free running clock of the Cortex®-M0. See ARM's Cortex®-M0 Technical Reference Manual for details.



# 4.2.1 Clock Tree Diagram



Figure 4-2 Clock Tree

1. The maximum frequency available for the system clock is 48MHz.

2. For more details about the internal and external clock source characteristics, please refer to the "Electrical Characteristics" section in the product datasheet.

### 4.2.2 HSI clock

By configuring PWR\_CTRL5.HSISEL, Select HSI (High Speed Internal) clock signal is generated by an internal 48MHz or 40MHz RC oscillator, which can be used directly as a system clock or input after dividing. The HSI RC



oscillator provides a clock source without any external devices.

RC oscillator frequencies can vary from one chip to another due to manufacturing process variations. Therefore, the HSI clock frequency of the chip has been calibrated to 1% (25 °C) before leaving the factory.

If the user application is subject to voltage or temperature variations, this may affect the accuracy of the RC oscillator. The HSI frequency can be trimmed by using the RCC\_HSICTRL.HSITRIM[3:0] bits.

The RCC\_CTRL.HSI48MRDF or RCC\_CTRL.HSI40MRDF bit flag indicates if the HSI RC oscillator is stable. At startup, the HSI RC output clock is not released until this bit is set by hardware.

## 4.2.3 LSI clock

The LSI RC can provide clock the IWDG and PWR in STOP mode. The LSI clock frequency is about 32KHz. Please refer to the electrical characteristics section of the data sheet for further information.

The RCC\_LSICTRL.LSIRDF bit flag indicates if the LSI clock is stable. At startup, the clock is not released until this bit is set by hardware.

#### 4.2.3.1 LSI calibration

Internal low-speed oscillator LSI frequency errors can be calibrated to obtain higher accuracy LPTIM (when clocked by LSI), Beeper, and IWDG time bases.

The LSI calibration steps are as follows:

- 1. Enable RCC\_LSICTRL.LSIDETEN, which initiates LSI clock calibration;
- 2. Check RCC\_LSICTRL.LSIDETFF flag bit, 1 indicates the end of calibration, read RCC\_LSICTRL.LSIFREQ[15:0];
- 3. Take the average of the RCC\_LSICTRL as many times as needed, and then cleared RCC\_LSICTRL.LSIDETFF flag, disable RCC\_LSICTRL.LSIDETEN;
- 4. Calculate actual LSI frequency according to the formula, LSICLK(kHz) = 8\*HSICLK/LSIFREQ[15:0] (HSICLK is 48000kHz or 40000kHz);
- 5. Adjust the RCC\_LSICTRL.LSITRIM[4:0] (default 16, adjustable step size 1kHz) according to the deviation of the actual LSI frequency from 32kHz

## 4.2.4 System clock (SYSCLK) selection

After the system reset, the HSI oscillator is selected as the system clock.

By configuring the HSI divider factor RCC\_CFG.SYSPRES[1:0], when the HSI is 48M, the system clock can be configured to 8M, 24M, or 48M; When the HSI is 40M, the system clock can be configured to 8M or 40M.

## 4.2.5 Watchdog clock

If the independent watchdog has been started by hardware option or software, the LSI oscillator will be forced on and cannot be turned off. The clock is supplied to the IWDG after the LSI oscillator is stable.



### 4.2.6 **TIM6 clock**

In normal working mode, the TIM6 clock supports 2 clock sources: PCLK and LSI. Since PCLK will be turned off in low power mode, software should switch the TIM6 clock to LSI before entering low power mode.

When LSI and PCLK are switched between each other, software must ensure that both clocks are turned on to switch without glitches.

## 4.2.7 Clock output(MCO)

The microcontroller clock output (MCO) capability allows the clock signal to be output onto the external MCO pin.

MCO pin is PA13, the corresponding GPIO port register must be configured for the corresponding function.

The following 2 clock signals can be selected as the MCO clock:

- HSI clock division
- LSI clock division

The MCO clock is selected by RCC\_CFG.MCO[1:0], and the clock is divided by RCC\_CFG.MCOPRES[3:0].

## 4.3 RCC registers

### 4.3.1 RCC register overview

| Offset | Register      | 31 | 30  | 29    | 28 | 27       | 26 | 25       | 24 | 23    | 22    | 5   | 20 |      | 19   | 18 | 17 | 16 | 15 | 3 | 14      | 13           | 12      | 11       | 10     | 6            | ×      | 7              | 9       | 5          | 4        | 3       | 2        | 1         | 0         |
|--------|---------------|----|-----|-------|----|----------|----|----------|----|-------|-------|-----|----|------|------|----|----|----|----|---|---------|--------------|---------|----------|--------|--------------|--------|----------------|---------|------------|----------|---------|----------|-----------|-----------|
| 000h   | RCC_HSICTRL   |    |     |       |    |          |    |          |    |       |       |     | Re | serv | red  |    |    |    |    |   |         |              |         |          |        |              |        |                |         | [M[3:      |          | -       | Keserved | HSI48MRDF | HSI40MRDF |
|        | Reset Value   |    |     |       |    |          | 1  |          | 1  |       |       |     |    |      |      |    |    |    |    |   |         |              |         |          |        |              |        | 1              | 0       | 0          | 0        |         |          | 1         | 0         |
| 004h   | RCC_CFG       | м  | COR | ES[3: | 0] | Reserved |    | MCO[1:0] |    |       |       |     | 1  | Rese | erve | d  |    |    |    |   |         | CVSDPFS[1.0] |         | Reserved |        | BPR<br>[2:0] |        | AF             | IBPR    | ES[3       | :0]      |         | Rese     | rved      |           |
|        | Reset Value   | 0  | 0   | 1     | 0  |          | 0  | 0        |    |       |       |     |    |      |      |    |    |    |    |   |         | 1            | 1       |          | 0      | 0            | 0      | 0              | 0       | 0          | 0        |         |          |           |           |
| 00Ch   | RCC_PRST      |    |     |       |    |          |    |          | Re | eserv | ed    |     |    |      |      |    |    |    |    |   | COMPRST | TIM6RST      | TIM3RST | TIMIRST  | SPIRST | Reserved     | ADCRST | PWRRST         | 12CRST  | UART2RST   | UARTIRST | IOPBRST | IOPARST  | BEEPERRST | AFIORST   |
|        | Reset Value   |    |     |       |    |          |    |          |    |       |       |     |    |      |      |    |    |    |    |   | 0       | 0            | 0       | 0        | 0      |              | 0      | 0              | 0       | 0          | 0        | 0       | 0        | 0         | 0         |
| 010h   | RCC_AHBPCLKEN |    |     |       |    |          |    |          |    | R     | eserv | /ed |    |      |      |    |    |    |    |   |         |              | ADCEN   |          | R      | eserv        | ed     |                | CRCEN   |            |          | Rese    | rved     |           |           |
|        | Reset Value   |    |     |       |    |          |    |          |    |       |       |     |    |      |      |    |    |    |    |   |         | ľ            | 0       |          |        |              |        |                | 0       |            |          |         |          |           |           |
| 014h   | RCC_APBPCLKEN |    |     |       |    |          |    |          | Re | eserv | ed    |     |    |      |      |    |    |    |    |   | IWDGEN  | TIM6EN       | TIM3EN  | TIMIEN   | SPIEN  | PWREN        | 12CEN  | <b>UART2EN</b> | UARTIEN | COMPFILTEN | COMPEN   | IOPBEN  | IOPAEN   | BEEPEREN  | AFIOEN    |
|        | Reset Value   |    |     |       |    |          |    |          |    |       |       |     |    |      |      |    |    |    |    |   | 1       | 0            | 0       | 0        | 0      | 1            | 0      | 0              | 0       | 0          | 0        | 0       | 0        | 0         | 0         |

#### Table 4-1 RCC register overview

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| 018h | RCC_LSICTRL |            |                   | Reserved | LSIDETHF |      |      |         |   |   | L | SIFREQ | 0[15 | :0] |   |          |         |                 |          |          | LSIDETEN |          | LSI     | 'RIM    | [4:0]   | I         | LSIRDF   | Reserved |
|------|-------------|------------|-------------------|----------|----------|------|------|---------|---|---|---|--------|------|-----|---|----------|---------|-----------------|----------|----------|----------|----------|---------|---------|---------|-----------|----------|----------|
|      | Reset Value |            |                   |          | 0        | 0    | )    | 0 0     | 0 | 0 | 0 | 0      | 0    | 0   | 0 | 0        | 0       | 0               | 0        | 0        | 0        | 1        | 0       | 0       | 0       | 0         | 1        | 0        |
| 01Ch | RCC_CTRLSTS |            |                   |          |          | R    | eser | ved     |   |   |   |        |      |     |   |          | EMCRSTF |                 | Reserved | LPWRRSTF | LVRRSTF  | IWDGRSTF | SFTRSTF | PORRSTF | PINRSTF |           | Keserved | RMRSTF   |
|      | Reset Value |            |                   |          |          |      |      |         |   |   |   |        |      |     |   |          | 0       |                 |          | 0        | 0        | 0        | 0       | 1       | 1       |           |          | 0        |
| 020h | RCC_CFG2    | TIMICLKSEL | <b>TIM6CLKSEL</b> |          |          |      | I    | Reserve | 1 |   |   |        |      |     |   |          |         | ADCIMPRES [1:0] |          |          | Rese     | rved     |         |         |         | ADC<br>[3 |          |          |
|      | Reset Value | 0          | 0                 |          |          |      |      |         |   |   |   |        |      |     |   |          | 1       | 1               |          |          |          |          |         |         | 0       | 0         | 0        | 1        |
| 024h | RCC_EMCCTRL |            |                   |          |          | Rese | rvec | 1       |   |   |   |        |      |     |   | EMCRSTEN |         |                 |          |          | R        | eserv    | ed      |         |         |           |          | EMCDETEN |
|      | Reset Value |            |                   |          |          |      |      |         |   |   |   |        |      |     |   | 0        |         |                 |          |          |          |          |         |         |         |           |          | 0        |

# 4.3.2 HSI clock control register (RCC\_HSICTRL)

Address offset: 0x00



| Bit field | Name         | Description                                                                          |
|-----------|--------------|--------------------------------------------------------------------------------------|
| 31:8      | Reserved     | Reserved, the reset value must be maintained.                                        |
| 7:4       | HSITRIM[3:0] | Internal high-speed clock trimming                                                   |
|           |              | Written by software to calibrate the frequency of the internal HSI RC oscillator for |
|           |              | higher accuracy as required by the application.                                      |
|           |              | The default value is 8, and the HSITRIM adjustment step is target frequency * 0.33%  |
|           |              | (the target frequency is 48M or 40M).                                                |
| 3:2       | Reserved     | Reserved, the reset value must be maintained.                                        |
| 1         | HSI48MRDF    | Internal 48M high-speed clock ready flag                                             |
|           |              | Set by hardware to indicate that internal 48 MHz RC oscillator is stable.            |
|           |              | 0: internal 48 MHz RC oscillator not ready                                           |
|           |              | 1: internal 48 MHz RC oscillator ready                                               |
| 0         | HSI40MRDF    | Internal 40M high-speed clock 40M ready flag                                         |
|           |              | Set by hardware to indicate that internal 40 MHz RC oscillator is stable.            |



| Bit field | Name | Description                                |
|-----------|------|--------------------------------------------|
|           |      | 0: internal 40 MHz RC oscillator not ready |
|           |      | 1: internal 40 MHz RC oscillator ready     |

# 4.3.3 Clock configuration register (RCC\_CFG)

Address offset: 0x04

| 31   |         |             | 28 | 27       | 26       | 25       | 24     |   |       |         |          |   |      |      | 16 |
|------|---------|-------------|----|----------|----------|----------|--------|---|-------|---------|----------|---|------|------|----|
|      | MCOPF   | ES[3:0]     |    | Reserved | MCC      | [1:0]    |        |   |       |         | Reserved |   |      |      |    |
| 15   | r<br>14 | 10          | 12 | 11       | rv<br>10 | N        | ۱<br>٥ | 7 | I     |         | 4        | 2 | 1    |      |    |
| Rese | erved   | 13<br>SYSPR |    | Reserved |          | PBPRES[2 | :0]    |   | AHBPR | ES[3:0] | 4<br>1   | 3 | Rese | rved |    |
|      | •       | r           | w  |          |          | rw       |        |   | rv    | N       |          |   |      |      |    |

| Bit field | Name         | Description                                                                    |
|-----------|--------------|--------------------------------------------------------------------------------|
| 31:28     | MCOPRES[3:0] | MCO prescaler                                                                  |
|           |              | Set and cleared by software.                                                   |
|           |              | 0000: LSI clock is divided by 1 as MCO clock; HSI clock is divided by 2 as MCO |
|           |              | clock                                                                          |
|           |              | 0001: LSI/HSI clock is divided by 2 as MCO clock                               |
|           |              | 0010: LSI/HSI clock is divided by 3 as MCO clock                               |
|           |              | 0011: LSI/HSI clock is divided by 4 as MCO clock                               |
|           |              | 0100: LSI/HSI clock is divided by 5 as MCO clock                               |
|           |              | 0101: LSI/HSI clock is divided by 6 as MCO clock                               |
|           |              | 0110: LSI/HSI clock is divided by 7 as MCO clock                               |
|           |              | 0111: LSI/HSI clock is divided by 8 as MCO clock                               |
|           |              | 1000: LSI/HSI clock is divided by 9 as MCO clock                               |
|           |              | 1001: LSI/HSI clock is divided by 10 as MCO clock                              |
|           |              | 1010: LSI/HSI clock is divided by 11 as MCO clock                              |
|           |              | 1011: LSI/HSI clock is divided by 12 as MCO clock                              |
|           |              | 1100: LSI/HSI clock is divided by 13 as MCO clock                              |
|           |              | 1101: LSI/HSI clock is divided by 14 as MCO clock                              |
|           |              | 1110: LSI/HSI clock is divided by 15 as MCO clock                              |
|           |              | 1111: LSI/HSI clock is divided by 32 as MCO clock                              |
| 27        | Reserved     | Reserved, the reset value must be maintained.                                  |
| 26:25     | MCO[1:0]     | Microcontroller clock output selection                                         |
|           |              | Set and cleared by software.                                                   |
|           |              | 00: no clock                                                                   |
|           |              | 01: LSI clock                                                                  |
|           |              | 10: LSE clock                                                                  |
|           |              | Others: Not allowed to set                                                     |





| Bit field | Name         | Description                                                                         |
|-----------|--------------|-------------------------------------------------------------------------------------|
|           |              | Note: This clock output may be truncated at startup or during MCO clock source      |
|           |              | switching.                                                                          |
|           |              | When the HSI clock is selected to output to the MCO pin, the output clock frequency |
|           |              | must not exceed the maximum I/O speed (For details of the maximum frequency of the  |
|           |              | I/O port, see the data sheet).                                                      |
| 24:14     | Reserved     | Reserved, the reset value must be maintained.                                       |
| 13:12     | SYSPRES[1:0] | Sysclk prescaler                                                                    |
|           |              | Set and cleared by software to control the division factor of the sysclk clock.     |
|           |              | When HSI is 48M:                                                                    |
|           |              | 00: HSI not divided as sysclk                                                       |
|           |              | 01: HSI divided by 2 as sysclk                                                      |
|           |              | Others: HSI divided by 6 as sysclk                                                  |
|           |              | When HSI is 40M:                                                                    |
|           |              | 00: HSI not divided as sysclk                                                       |
|           |              | Others: HSI divided by 5 as sysclk                                                  |
|           |              | Note: After exiting STOP, the bit reverts to the reset value.                       |
| 11        | Reserved     | Reserved, the reset value must be maintained.                                       |
| 10:8      | APBPRES[2:0] | APB prescaler                                                                       |
|           |              | Set and cleared by software to control the division factor of the APB clock(PCLK).  |
|           |              | 0xx: HCLK not divided                                                               |
|           |              | 100: HCLK divided by 2                                                              |
|           |              | 101: HCLK divided by 4                                                              |
|           |              | 110: HCLK divided by 8                                                              |
|           |              | 111: HCLK divided by 16                                                             |
| 7:4       | AHBPRES[3:0] | AHBPRE: AHB prescaler                                                               |
|           |              | Set and cleared by software to control the division factor of the AHB clock(HCLK).  |
|           |              | 0xxx: SYSCLK not divided                                                            |
|           |              | 1000: SYSCLK divided by 2                                                           |
|           |              | 1001: SYSCLK divided by 4                                                           |
|           |              | 1010: SYSCLK divided by 8                                                           |
|           |              | 1011: SYSCLK divided by 12                                                          |
|           |              | 1100: SYSCLK divided by 16                                                          |
|           |              | Others: SYSCLK divided by 24                                                        |
| 3:0       | Reserved     | Reserved, the reset value must be maintained.                                       |

# 4.3.4 Peripheral reset register (RCC\_PRST)

Address offset: 0x0c



| 31       |             |         |         |         |        |          |        |        |        |              |              |         |         |               | 16      |
|----------|-------------|---------|---------|---------|--------|----------|--------|--------|--------|--------------|--------------|---------|---------|---------------|---------|
|          | I           |         | I       |         | I      | I        | Rese   | erved  |        | I            | I            | I       | I       | I             | '       |
|          | 1           |         | 1       |         | 1      | 1        | 1      |        |        |              |              | 1       | 1       |               | L]      |
| 15       | 14          | 13      | 12      | 11      | 10     | 9        | 8      | 7      | 6      | 5            | 4            | 3       | 2       | 1             | 0       |
| Reserved | COMP<br>RST | TIM6RST | TIM3RST | TIM1RST | SPIRST | Reserved | ADCRST | PWRRST | I2CRST | UART2<br>RST | UART1<br>RST | IOPBRST | IOPARST | BEEPER<br>RST | AFIORST |
|          | rw          | rw      | rw      | rw      | rw     |          | rw     | rw     | rw     | rw           | rw           | rw      | rw      | rw            | rw      |

| Bit field | Name     | Description                                   |
|-----------|----------|-----------------------------------------------|
| 31:15     | Reserved | Reserved, the reset value must be maintained. |
| 14        | COMPRST  | COMP reset                                    |
|           |          | Set and cleared by software.                  |
|           |          | 0: Clear reset                                |
|           |          | 1: Reset COMP                                 |
| 13        | TIM6RST  | TIM6 reset                                    |
|           |          | Set and cleared by software.                  |
|           |          | 0: Clear reset                                |
|           |          | 1: Reset TIM6                                 |
| 12        | TIM3RST  | TIM3 reset                                    |
|           |          | Set and cleared by software.                  |
|           |          | 0: Clear reset                                |
|           |          | 1: Resets TIM3                                |
| 11        | TIM1RST  | TIM1 reset                                    |
|           |          | Set and cleared by software.                  |
|           |          | 0: Clear reset                                |
|           |          | 1: Resets TIM1                                |
| 10        | SPIRST   | SPI reset                                     |
|           |          | Set and cleared by software.                  |
|           |          | 0: Clear reset                                |
|           |          | 1: Reset SPI                                  |
| 9         | Reserved | Reserved, the reset value must be maintained. |
| 8         | ADCRST   | ADC reset                                     |
|           |          | Set and cleared by software.                  |
|           |          | 0: Clear reset                                |
|           |          | 1: Reset ADC                                  |
| 7         | PWRRST   | Power interface reset                         |
|           |          | Set and cleared by software.                  |
|           |          | 0: Clear reset                                |
|           |          | 1: Reset the power interface                  |
| 6         | I2CRST   | I2C reset                                     |
|           |          | Set and cleared by software.                  |
|           |          | 0: Clear reset                                |
|           |          | 1: Reset I2C                                  |
| 5         | UART2RST | UART2 reset                                   |
|           |          |                                               |



| Bit field | Name      | Description                    |
|-----------|-----------|--------------------------------|
|           |           | Set and cleared by software.   |
|           |           | 0: Clear reset                 |
|           |           | 1: Reset UART2                 |
| 4         | UART1RST  | UART1 reset                    |
|           |           | Set and cleared by software.   |
|           |           | 0: Clear reset                 |
|           |           | 1: Reset UART1                 |
| 3         | IOPBRST   | GPIO port B reset              |
|           |           | Set and cleared by software.   |
|           |           | 0: Clear reset                 |
|           |           | 1: Reset GPIO port B           |
| 2         | IOPARST   | GPIO port A reset              |
|           |           | Set and cleared by software.   |
|           |           | 0: Clear reset                 |
|           |           | 1: Reset GPIO port A           |
| 1         | BEEPERRST | Beeper reset                   |
|           |           | Set and cleared by software.   |
|           |           | 0: Clear reset                 |
|           |           | 1: Reset Beeper                |
| 0         | AFIORST   | Alternate function IO reset    |
|           |           | Set and cleared by software.   |
|           |           | 0: Clear reset                 |
|           |           | 1: Reset alternate function IO |

# 4.3.5 AHB peripheral clock enable register (RCC\_AHBPCLKEN)

Address offset: 0x10



| Bit field | Name     | Description                                   |
|-----------|----------|-----------------------------------------------|
| 31:13     | Reserved | Reserved, the reset value must be maintained. |
| 12        | ADCEN    | ADC clock enable                              |
|           |          | Set and cleared by software.                  |
|           |          | 0: Disable ADC clock                          |
|           |          | 1: Enable ADC clock                           |
| 11:7      | Reserved | Reserved, the reset value must be maintained. |



| Bit field | Name     | Description                                   |
|-----------|----------|-----------------------------------------------|
| 6         | CRCEN    | CRC clock enable                              |
|           |          | Set and cleared by software.                  |
|           |          | 0: Disable CRC clock                          |
|           |          | 1: Enable CRC clock                           |
| 5:0       | Reserved | Reserved, the reset value must be maintained. |

# 4.3.6 APB peripheral clock enable register (RCC\_APBPCLKEN)

Address offset: 0x14



| Bit field | Name     | Description                                   |  |
|-----------|----------|-----------------------------------------------|--|
| 31:15     | Reserved | Reserved, the reset value must be maintained. |  |
| 14        | IWDGEN   | IWDG clock enable                             |  |
|           |          | Set and cleared by software.                  |  |
|           |          | 0: Disable IWDG clock                         |  |
|           |          | 1: Enable IWDG clock                          |  |
| 13        | TIM6EN   | TIM6 Clock Enable                             |  |
|           |          | Set and cleared by software.                  |  |
|           |          | 0: Disable TIM6 clock                         |  |
|           |          | 1: Enable TIM6 clock                          |  |
| 12        | TIM3EN   | TIM3 clock enable                             |  |
|           |          | Set and cleared by software.                  |  |
|           |          | 0: Disable TIM3 clock                         |  |
|           |          | 1: Enable TIM3 clock                          |  |
| 11        | TIM1EN   | TIM1 clock enable                             |  |
|           |          | Set and cleared by software.                  |  |
|           |          | 0: Disable TIM1 clock                         |  |
|           |          | 1: Enable TIM1 clock                          |  |
| 10        | SPIEN    | SPI clock enable                              |  |
|           |          | Set and cleared by software.                  |  |
|           |          | 0: Disable SPI clock                          |  |
|           |          | 1: Enable SPI clock                           |  |
| 9         | PWREN    | Power interface clock enable                  |  |
|           |          | Set and cleared by software.                  |  |
|           |          | 0: Disable the power interface clock          |  |



| Bit field | Name       | Description                                |
|-----------|------------|--------------------------------------------|
|           |            | 1: Enable the power interface clock        |
| 8         | I2CEN      | I2C clock enable                           |
|           |            | Set and cleared by software.               |
|           |            | 0: Disable I2C clock                       |
|           |            | 1: Enable I2C clock                        |
| 7         | UART2EN    | UART2 clock enable                         |
|           |            | Set and cleared by software.               |
|           |            | 0: Disable UART2 clock                     |
|           |            | 1: Enable UART2 clock                      |
| 6         | UART1EN    | UART1 clock enable                         |
|           |            | Set and cleared by software.               |
|           |            | 0: Disable UART1 clock                     |
|           |            | 1: Enable UART1 clock                      |
| 5         | COMPFILTEN | COMP filter clock enable                   |
|           |            | 0: Disable the comparator filter clock     |
|           |            | 1: Enable the comparator filter clock      |
| 4         | COMPEN     | COMP clock enable                          |
|           |            | 0: Disable the comparator clock            |
|           |            | 1: Enable the comparator clock             |
| 3         | IOPBEN     | GPIO port B clock enable                   |
|           |            | Set and cleared by software.               |
|           |            | 0: Disable the clock of GPIO port B        |
|           |            | 1: Enable the clock of GPIO port B         |
| 2         | IOPAEN     | GPIO port A clock enable                   |
|           |            | Set and cleared by software.               |
|           |            | 0: Disable the clock of GPIO port A        |
|           |            | 1: Enable the clock of GPIO port A         |
| 1         | BEEPEREN   | Beeper clock enable                        |
|           |            | 0: Disable the Beeper clock                |
|           |            | 1: Enable the Beeper clock                 |
| 0         | AFIOEN     | Alternate function IO clock enable         |
|           |            | Set and cleared by software.               |
|           |            | 0: Disable the alternate function IO clock |
|           |            | 1: Enable the alternate function IO clock  |

# 4.3.7 Low speed clock control register (RCC\_LSICTRL)

Address offset: 0x18



| 31 |   |   |          |         | 25 | 24       | 23       |   |   |           |          |   |        | 16       |
|----|---|---|----------|---------|----|----------|----------|---|---|-----------|----------|---|--------|----------|
|    |   |   | Reserved |         |    | LSIDETFF |          |   |   | LSIFRE    | EQ[15:0] | 1 | 1      |          |
| 15 | 1 |   |          |         |    | r<br>8   | 7        | 6 |   |           | r        | 2 | 1      | 0        |
|    | 1 | 1 | LSIFRE   | Q[15:0] |    |          | LSIDETEN |   | L | SITRIM[4: | 0]       |   | LSIRDF | Reserved |
|    |   |   | 1        | •       |    |          | rw       |   |   | rw        |          |   | r      |          |

| Bit field | Name          | Description                                                                          |
|-----------|---------------|--------------------------------------------------------------------------------------|
| 31:25     | Reserved      | Reserved, the reset value must be maintained                                         |
| 24        | LSIDETFF      | LSI detect finish flag                                                               |
|           |               | Set by the hardware, and it is cleared by the disable LSIDETEN bit.                  |
|           |               | 0: LSI detection has not finish                                                      |
|           |               | 1: LSI detect finish                                                                 |
| 23:8      | LSIFREQ[15:0] | LSI detect cnt                                                                       |
|           |               | Read-only, can be used for LSI frequency calibration.                                |
|           |               | Actual LSI frequency LSICLK(kHz)= 8*HSICLK/LSIFREQ[15:0] (HSICLK is                  |
|           |               | 48000kHz or 40000kHz)                                                                |
| 7         | LSIDETEN      | LSI detect enable                                                                    |
|           |               | Set and cleared by software                                                          |
|           |               | 0: Disable LSI detect                                                                |
|           |               | 1: Enable LSI detect                                                                 |
| 6:2       | LSITRIM[4:0]  | Internal low-speed clock trimming                                                    |
|           |               | Written by software to calibrate the frequency of the internal LSI RC oscillator for |
|           |               | higher accuracy as required by the application.                                      |
|           |               | The default value is 16, and the LSITRIM adjustment step is 1kHz.                    |
| 1         | LSIRDF        | Internal low-speed oscillator ready                                                  |
|           |               | Set and cleared by hardware to indicate when the LSI is stable.                      |
|           |               | 0: LSI not ready                                                                     |
|           |               | 1: LSI ready                                                                         |
| 0         | Reserved      | Reserved, the reset value must be maintained                                         |

# 4.3.8 Control/status register (RCC\_CTRLSTS)

Address offset: 0x1c

| 31 |          |    |         |      |      |              |             |              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |     |       | 16     |
|----|----------|----|---------|------|------|--------------|-------------|--------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----|-------|--------|
|    |          |    |         |      |      | Rese         | rved        |              |             | I Contraction of the second seco |         | I   | •     | '      |
|    | 11       | 1  | I I     |      | 1    | 1            | 1           | I            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1       | 1   | 1     |        |
| 15 |          | 12 | 11      | 10   | 9    | 8            | 7           | 6            | 5           | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 3       | 2   | 1     | 0      |
|    | Reserved | 1  | EMCRSTF | Rese | rved | LPWR<br>RSTF | LVR<br>RSTF | IWDG<br>RSTF | SFT<br>RSTF | POR<br>RSTF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | PINRSTF | Res | erved | RMRSTF |
|    |          |    | r       |      |      | r            | r           | r            | r           | r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | r       |     |       | rw     |

| Bit field | Name     | Description                                  |
|-----------|----------|----------------------------------------------|
| 31:12     | Reserved | Reserved, the reset value must be maintained |



| Bit field | Name     | Description                                               |  |  |  |  |
|-----------|----------|-----------------------------------------------------------|--|--|--|--|
| 11        | EMCRSTF  | EMC reset flag                                            |  |  |  |  |
|           |          | Set by hardware when EMC clamp is reset.                  |  |  |  |  |
|           |          | It is cleared by writing RMRSTF bit.                      |  |  |  |  |
|           |          | 0: No EMC clamp reset occurred                            |  |  |  |  |
|           |          | 1: EMC clamp reset occurred                               |  |  |  |  |
| 10:9      | Reserved | Reserved, the reset value must be maintained              |  |  |  |  |
| 8         | LPWRRSTF | Low-power reset flag                                      |  |  |  |  |
|           |          | Set by hardware at Low-power reset.                       |  |  |  |  |
|           |          | It is cleared by writing RMRSTF bit.                      |  |  |  |  |
|           |          | 0: No Low-power reset occurred                            |  |  |  |  |
|           |          | 1: Low-power reset occurred                               |  |  |  |  |
| 7         | LVRRSTF  | LVR reset flag                                            |  |  |  |  |
|           |          | Set by hardware at LVR reset.                             |  |  |  |  |
|           |          | It is cleared by writing RMRSTF bit.                      |  |  |  |  |
|           |          | 0: No Low-power reset occurred                            |  |  |  |  |
|           |          | 1: Low-power reset occurred                               |  |  |  |  |
| 6         | IWDGRSTF | Independent watchdog reset flag                           |  |  |  |  |
|           |          | Set by hardware when an independent watchdog reset occurs |  |  |  |  |
|           |          | It is cleared by writing RMRSTF bit.                      |  |  |  |  |
|           |          | 0: No independent watchdog reset occurred                 |  |  |  |  |
|           |          | 1: Independent watchdog reset occurred                    |  |  |  |  |
| 5         | SFTRSTF  | Software reset flag                                       |  |  |  |  |
|           |          | Set by hardware when a software reset occurs.             |  |  |  |  |
|           |          | It is cleared by writing RMRSTF bit.                      |  |  |  |  |
|           |          | 0: No software reset occurred                             |  |  |  |  |
|           |          | 1: Software reset occurred                                |  |  |  |  |
| 4         | PORRSTF  | POR/PDR reset flag                                        |  |  |  |  |
|           |          | Set by hardware when POR/PDR is reset.                    |  |  |  |  |
|           |          | Cleared by writing to the RMRSTF bit                      |  |  |  |  |
|           |          | 0: No POR/PDR reset occurred                              |  |  |  |  |
|           |          | 1: POR/PDR reset occurred                                 |  |  |  |  |
| 3         | PINRSTF  | External pin reset flag                                   |  |  |  |  |
|           |          | Set by hardware when a reset from the NRST pin occurs.    |  |  |  |  |
|           |          | It is cleared by writing RMRSTF bit.                      |  |  |  |  |
|           |          | 0: No NRST pin reset occurred                             |  |  |  |  |
|           |          | 1: NRST pin reset occurred                                |  |  |  |  |
| 2:1       | Reserved | Reserved, the reset value must be maintained              |  |  |  |  |
| 0         | RMRSTF   | Remove reset flag                                         |  |  |  |  |
|           |          | Set and clear by software                                 |  |  |  |  |
|           |          | 0: No effect                                              |  |  |  |  |
|           |          | 1: Clear these reset flags                                |  |  |  |  |
|           |          | -                                                         |  |  |  |  |



# 4.3.9 Clock configuration register 2 (RCC\_CFG2)

Address offset: 0x20

| 31             | 30             | 29   |    |    |              |   | - |      |       |   |   |   |       |         | 16 |
|----------------|----------------|------|----|----|--------------|---|---|------|-------|---|---|---|-------|---------|----|
| TIM1CLK<br>SEL | TIM6CLK<br>SEL |      | 1  | 1  | I            | I | I | Rese | erved | I | 1 | 1 | 1     |         |    |
| rw<br>15       | rw             |      | 12 | 11 | 10           | 9 |   |      |       |   | 4 | 3 |       |         | 0  |
|                | Rese           | rved | 1  |    | MPRES<br>:0] |   | 1 | Rese | erved | 1 | 1 |   | ADCPR | ES[3:0] |    |
|                |                |      |    | r  | w            |   |   |      |       |   |   |   | r     | w       |    |

| Bit field | Name           | Description                                                                              |  |  |  |  |
|-----------|----------------|------------------------------------------------------------------------------------------|--|--|--|--|
| 31        | TIM1CLKSEL     | TIM1 clock source selection                                                              |  |  |  |  |
|           |                | Set and cleared by software.                                                             |  |  |  |  |
|           |                | 0: PCLK is selected as TIM1 clock source if APB prescaler is 1. Otherwise, PCLK $\times$ |  |  |  |  |
|           |                | 2 is selected.                                                                           |  |  |  |  |
|           |                | 1: SYSCLK clock is selected as TIM1 clock source.                                        |  |  |  |  |
| 30        | TIM6CLKSEL     | TIM6 clock source selection                                                              |  |  |  |  |
|           |                | Set and cleared by software.                                                             |  |  |  |  |
|           |                | 0: PCLK is selected as TIM6 clock source if APB prescaler is 1. Otherwise, PCLK $\times$ |  |  |  |  |
|           |                | 2 is selected.                                                                           |  |  |  |  |
|           |                | 1: LSI clock is selected as TIM6 clock source.                                           |  |  |  |  |
| 29:12     | Reserved       | Reserved, the reset value must be maintained.                                            |  |  |  |  |
| 11:10     | ADC1MPRES[1:0] | ADC 1M clock prescaler                                                                   |  |  |  |  |
|           |                | Set and cleared by software to configure the division factor of ADC 1M clock source.     |  |  |  |  |
|           |                | To ensure normal work of the ADC module, the HSI divide result must be 1M.               |  |  |  |  |
|           |                | When HSI is 48M:                                                                         |  |  |  |  |
|           |                | 00: HSI divided by 6 as ADC 1M clock                                                     |  |  |  |  |
|           |                | 01: HSI divided by 12 as ADC 1M clock                                                    |  |  |  |  |
|           |                | 10: HSI divided by 24 as ADC 1M clock                                                    |  |  |  |  |
|           |                | 11: HSI divided by 48 as ADC 1M clock                                                    |  |  |  |  |
|           |                | When HSI is 40M:                                                                         |  |  |  |  |
|           |                | 00~11: HSI divided by 40 as ADC 1M clock                                                 |  |  |  |  |
| 9:4       | Reserved       | Reserved, the reset value must be maintained.                                            |  |  |  |  |
| 3:0       | ADCPRES[3:0]   | ADC work clock prescaler                                                                 |  |  |  |  |
|           |                | Set and cleared by software to configure the division factor of the ADC working          |  |  |  |  |
|           |                | clock source.                                                                            |  |  |  |  |
|           |                | To ensure normal work of the ADC module, the ADC working clock source cannot             |  |  |  |  |
|           |                | exceed 24M.                                                                              |  |  |  |  |
|           |                | 0000: HSI not divided as ADC work clock                                                  |  |  |  |  |
|           |                | 0001: HSI divided by 2 as ADC work clock                                                 |  |  |  |  |
|           |                | 0010: HSI divided by 3 as ADC work clock                                                 |  |  |  |  |



| Bit field | Name | Description                                 |  |  |  |
|-----------|------|---------------------------------------------|--|--|--|
|           |      | 0011: HSI divided by 4 as ADC work clock    |  |  |  |
|           |      | 0100: HSI divided by 6 as ADC work clock    |  |  |  |
|           |      | 0101: HSI divided by 8 as ADC work clock    |  |  |  |
|           |      | 0110: HSI divided by 10 as ADC work clock   |  |  |  |
|           |      | 0111: HSI divided by 12 as ADC work clock   |  |  |  |
|           |      | 1000: HSI divided by 24 as ADC work clock   |  |  |  |
|           |      | 1001: HSI divided by 32 as ADC work clock   |  |  |  |
|           |      | Others: HSI divided by 32 as ADC work clock |  |  |  |

# 4.3.10 EMC control register (RCC\_EMCCTRL)

Address offset: 0x24



| Bit field | Name     | Description                                   |  |
|-----------|----------|-----------------------------------------------|--|
| 31:24     | Reserved | Reserved, the reset value must be maintained. |  |
| 12        | EMCRSTEN | EMC reset enable                              |  |
|           |          | Set and cleared by software.                  |  |
|           |          | 0: Disable reset requests                     |  |
|           |          | 1: Enable reset requests                      |  |
| 11:1      | Reserved | Reserved, the reset value must be maintained. |  |
| 0         | EMCDETEN | EMC clamp detect enable                       |  |
|           |          | Set and cleared by software.                  |  |
|           |          | 0: Disable detect                             |  |
|           |          | 1: Enable detect                              |  |



# **5 GPIO and AFIO**

## 5.1 Summary

Supports 18 GPIO, divided into 2 groups (GPIOA/GPIOB), GPIOA have 16 pins, GPIOB has 2 pins. Each GPIO pin can be configured by software as output (push-pull or open drain), input (with or without pull-up or pull-down) or alternate peripheral function ports (output/input), most GPIO pins are shared with digital or analog reuse peripherals, some IO pins are also reused with clock pins. Except for ports with analog input function, all GPIO pins have the ability to pass through a large current.

GPIO ports have the following features:

- GPIO port can be configured with the following modes by software:
  - ♦ Input floating
  - ♦ Input pull-up
  - Input pull-down
  - Analog function
  - Open drain output and pull-up/pull-down can be configured
  - Push-pull output and pull-up/pull-down can be configured
  - Push-pull alternate function and pull-up/pull-down can be configured
  - Open-drain alternate function and pull-up/pull-down can be configured
- Individual bit setting or bit clearing function
- All I/O support external interrupt function
- All I/O support low power mode wake up, rising or falling edge configurable
  - 18 EXTI can be used for wake up in STOP mode, and all I/O can be reused as EXTI
  - NRST(PA0)/PA1/PA2 three wake up IOs can be used for PD mode wake up, I/O filtering time maximum lus
- Supports software remapping I/O alternate function
- Support GPIO lock mechanism, reset the lock state to clear

Each I/O port bit can be programmed arbitrarily, but the I/O port register must be accessed as a 32-bit word (16-bit half-word or 8-bit byte are not allowed). The following figure shows the basic structure of an I/O port.



#### Figure 5-1 Basic structure of an I/O port



# **5.2 IO function description**

## 5.2.1 **IO mode configuration**

The I/O port mode can be configured through the registers GPIOx\_PMODE (x=A to B), GPIOx\_POTYPE (x=A to B) and GPIOx\_PUPD (x=A to B). The configuration of different operation modes is shown in the following table:

| PMODE[1:0] | POTYPE | PUP | D[1:0] | The I/O configuration                         |
|------------|--------|-----|--------|-----------------------------------------------|
|            | 0      | 0   | 0      | General-purpose output push-pull              |
|            | 0      | 0   | 1      | General-purpose output push-pull + pull-up    |
|            | 0      | 1   | 0      | General-purpose output push-pull + pull-down  |
| 01         | 0      | 1   | 1      | Reserved                                      |
| 01         | 1      | 0   | 0      | General-purpose output open-drain             |
|            | 1      | 0   | 1      | General-purpose output open-drain + pull-up   |
|            | 1      | 1   | 0      | General-purpose output open-drain + pull-down |
|            | 1      | 1   | 1      | Reserved                                      |
|            | 0      | 0   | 0      | Alternate function push-pull                  |
|            | 0      | 0   | 1      | Alternate function push-pull + pull-up        |
|            | 0      | 1   | 0      | Alternate function push-pull + pull-down      |
| 10         | 0      | 1   | 1      | Reserved                                      |
|            | 1      | 0   | 0      | Alternate function open-drain                 |
|            | 1      | 0   | 1      | Alternate function open-drain + pull-up       |
|            | 1      | 1   | 0      | Alternate function open-drain + pull-down     |

Table 5-1 Relationship between I/O modes and configurations

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| PMODE[1:0] | POTYPE | PUPD[1:0] |   | The I/O configuration |
|------------|--------|-----------|---|-----------------------|
|            | 1      | 1         | 1 | Reserved              |
|            | Х      | 0         | 0 | Input floating        |
| 00         | Х      | 0         | 1 | Input pull-up         |
| 00         | Х      | 1         | 0 | Input pull-down       |
|            | х      | 1         | 1 | Reserved              |
|            | Х      | 0         | 0 | Analog                |
| 11         | Х      | 0         | 1 |                       |
|            | Х      | 1         | 0 | Reserved              |
|            | Х      | 1         | 1 |                       |

In addition, the GPIOx\_DS.DSy (x=A to B) bit can be used to configure the high/low drive strength, and the GPIOx\_SR.SRy (x=A to B) bit can be used to configure the fast/slow slew rate.

The input and output characteristics of I/O under different configurations are shown in the following table:

| Characteristic                      | <b>GPIO</b> input                  | GPIO output                                                                                              | Analog input                    | Peripheral alternate                                                                                     |
|-------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------|
| Output buffer                       | Disable                            | Enable                                                                                                   | Disable                         | Configure according to peripheral function                                                               |
| Schmitt trigger                     | Enable                             | Enable                                                                                                   | Disable<br>The output value is  | Enable                                                                                                   |
| Pull-up/pull-down/floating          | Configured                         | Configured                                                                                               | forced to be 0<br>Disable       | Configure according to<br>peripheral function                                                            |
| Open-drain mode                     | Disable                            | Can be configured, GPIO<br>output 0 when output data is<br>"0", high resistance of GPIO<br>when "1"      | Disable                         | Can be configured, GPIO<br>output 0 when output data is<br>"0", high resistance of GPIO<br>when "1"      |
| Push-pull mode                      | Disable                            | Can be configured, GPIO<br>output 0 when output data is<br>"0", GPIO output 1 when<br>output data is "1" | Disable                         | Can be configured, GPIO<br>output 0 when output data is<br>"0", GPIO output 1 when<br>output data is "1" |
| Input data register (IO state)      | Readable<br>(I/O status)           | Readable<br>(I/O status)                                                                                 | Read as 0<br>(Schmitt OFF)      | Readable<br>(I/O status)                                                                                 |
| Output data register (Output value) | Invalid<br>(last written<br>value) | Readable and written                                                                                     | Invalid<br>(last written value) | Readable                                                                                                 |

### 5.2.1.1 **Input mode**

When I/O port is configured in input mode:

- Output buffer is disabled
- The schmidt trigger input is activated



- Whether the pull-up and pull-down resistors are connected depends on the configuration of the GPIOx\_PUPD (x=A to B) register
- The data that appears on the I/O pin is sampled to the input data register on each APB clock
- Read access to the input data register can get I/O status

#### Figure 5-2 Input mode



### 5.2.1.2 **Output mode**

When I/O port is configured as output mode:

- The schmidt trigger input is activated
- Whether the pull-up and pull-down resistors are connected depends on the configuration of the GPIOx\_PUPD (x=A to B) register
- The output buffer is activated.
  - Open drain mode: '0' on the output register activates the N-MOS, the pin outputs a low level. while '1' on the output register puts the port in a high resistance state (P-MOS is never activated).
  - Push-pull mode: '0' on the output register activates the N-MOS, the pin outputs a low level. While '1' on the output register activates the P-MOS, the pin outputs a high level.
- The data that appears on the I/O pin is sampled to the input data register on each APB clock.
- Read access to input data register to get I/O status.
- Read access to the output data register to get the last written value.



#### Figure 5-3 Output mode



### 5.2.1.3 Alternate functional mode

When the I/O port is configured as alternate function mode:

- The schmidt trigger input is activated.
- Whether the pull-up and pull-down resistors are connected depends on the configuration of the GPIOx\_PUPD (x=A to B) register
- In the open-drain or push-pull configuration, the output buffer is controlled by the peripheral.
- Signal-driven output buffers for built-in peripherals.
- At each APB clock cycle, the data appearing on the I/O pin is sampled into the input data register.
- Read access to input data register to get I/O status.
- Read access to the output data register to get the last written value.



#### Figure 5-4 Alternate function mode



### 5.2.1.4 Analog mode

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

- The pull-up and pull-down resistors are disabled.
- Read access to the input data register gets the value "0".
- The output buffer is disabled.
- Schmitt trigger input is disabled and output value is forced to '0' (achieves zero consumption on each analog I/O pin).







## 5.2.2 Status after reset

During and just after reset, the alternate functions are not active, and the I/O ports are configured as analog mode (GPIOx\_PMODE.PMODEy[1:0] = 11). However, with the exception of the I/O ports below.

 $\blacksquare NRST (PA0) :$ 

- ♦ NRST input pull-up
- ◆ FLASH\_OB.NRST\_PA0=1 (default): as NRST pull-up input
- FLASH\_OB.NRST\_PA0=0: as a normal GPIO, it cannot be connected low level during power-on when used as an input (otherwise the chip will always be in reset)
- After reset, debug system-related pins are configured to SWD interface I/O configuration by default:
  - PA9: SWCLK in input pull-down mode
  - PA8: SWDIO in input pull-up mode

## 5.2.3 Individual bit setting and bit clearing

By writing '1' to the bit to be changed in the bit set/clear register (GPIOx\_PBSC) (x=A to B) and bit clear register (GPIOx\_PBC) (x=A to B), the individual bit operation of the data register (GPIOx\_POD) (x=A to B) can be realized, and one or more bits can be set/clear. The bit written with '1' is set or cleared accordingly, and the bit not written with '1' will not be changed. The software does not need to disable interrupts, and is completed in a single APB write operation.

## 5.2.4 External interrupt/wake-up line

All ports have external interrupt capability, which can be configured in the EXTI module:

- In order to use an external interrupt line, the port must be configured in input mode
- All ports can be configured for STOP mode wake-up, supporting rising or falling edge configurable.
- NRST(PA0)/PA1\_WKUP0/PA2\_WKUP1 can be used for PD mode wake up, with independent wake-up enable, support rising edge / falling edge can be configured, need to configure before entering PD mode.
- General purpose I/O ports are connected to 18 external interrupt/event lines, configured by registers AFIO\_CFG.EXTI\_SEL[4:0].

| EXTI Line Selection | Pin |
|---------------------|-----|
| EXTI Line0          | PA0 |
| EXTI Line1          | PA1 |
| EXTI Line2          | PA2 |
| EXTI Line3          | PA3 |
| EXTI Line4          | PA4 |
| EXTI Line5          | PA5 |

Table 5-3 Correspondence between EXTI Line and Pin



| EXTI Line6  | PA6  |
|-------------|------|
| EXTI Line7  | PA7  |
| EXTI Line8  | PA8  |
| EXTI Line9  | PA9  |
| EXTI Line10 | PA10 |
| EXTI Line11 | PA11 |
| EXTI Line12 | PA12 |
| EXTI Line13 | PA13 |
| EXTI Line14 | PA14 |
| EXTI Line15 | PA15 |
| EXTI Line16 | PB0  |
| EXTI Line17 | PB1  |

## 5.2.5 Alternate function

When I/O ports are configured for alternate function mode, the port bit configuration register (GPIOx\_AFL,GPIOx\_AFH,GPIOx\_PMODE, GPIOx\_POTYPE and GPIOx\_PUPD) must be programmed before using. The alternate input or output is determined by the peripheral.

### 5.2.5.1 Software remaping I/O alternate function

To expand the flexibility of alternate peripheral functions under different device packages, some peripheral alternate functions can be remapped to other pins. Each I/O has up to 16 alternate functions (AF0~AF15). After reset, except for PA8 and PA9, other pins' alternate function is AF15(AFSELy = AF15). The I/O alternate function can be remapped by software configuring the corresponding registers (GPIOx\_AFL/ GPIOx\_AFH).

At this time, the alternate functions are no longer mapped to their original pins (For the I/O alternate function of the peripheral, if it is remapped to a different pin, then the input is remapping choose one of multiple, and the output will be connected to the remapped position, and the original position will be disconnected).

### 5.2.5.2 SWD alternate function I/O remapping

#### Table 5-4 I/O List of functional features of the pin

| Alternate function | Pin | Remap |
|--------------------|-----|-------|
| SWDIO              | PA8 | AF0   |
| SWCLK              | PA9 | AF0   |

### 5.2.5.3 TIMx alternate function I/O remapping

### 5.2.5.3.1 TIM1 alternate function I/O remapping

Table 5-5 TIM1 alternate function I/O remapping

| Alternate function | Pin  | Remap |
|--------------------|------|-------|
| TIM1 ETD           | PA14 | AF5   |
| TIM1_ETR           | PA15 | AF5   |
| TIM1_BKIN          | PA1  | AF4   |
|                    | PA5  | AF4   |



| Alternate function | Pin  | Remap |
|--------------------|------|-------|
|                    | PA9  | AF4   |
|                    | PA6  | AF4   |
| TIM1_CH1           | PA11 | AF0   |
|                    | PB0  | AF4   |
|                    | PA7  | AF4   |
|                    | PA12 | AF3   |
| TIM1_CH2           | PA14 | AF3   |
|                    | PA15 | AF4   |
|                    | PA1  | AF3   |
|                    | PA7  | AF5   |
| TIM1_CH3           | PA10 | AF2   |
|                    | PA11 | AF4   |
|                    | PA3  | AF3   |
|                    | PA6  | AF3   |
|                    | PA7  | AF3   |
|                    | PA8  | AF2   |
|                    | PA10 | AF3   |
| TIM1_CH4           | PA11 | AF3   |
|                    | PA12 | AF4   |
|                    | PA13 | AF3   |
|                    | PA14 | AF4   |
|                    | PA15 | AF3   |
|                    | PB1  | AF4   |
|                    | PA5  | AF2   |
| TIM1_CH1N          | PA11 | AF5   |
|                    | PA13 | AF5   |
|                    | PA6  | AF5   |
| TIM1_CH2N          | PA12 | AF5   |
|                    | PA13 | AF4   |
|                    | PA2  | AF4   |
| TIM1 CHON          | PA3  | AF4   |
| TIM1_CH3N          | PA4  | AF4   |
|                    | PA10 | AF4   |

## 5.2.5.3.2 TIM3 alternate function I/O remapping

Table 5-6 TIM3 alternate function I/O remapping

| Alternate function | Pin | Remap |
|--------------------|-----|-------|
| TIM2 ETD           | PA9 | AF2   |
| TIM3_ETR           | PB1 | AF1   |
| TIM3_CH1           | PA1 | AF2   |
|                    | PA3 | AF1   |



| Alternate function | Pin  | Remap |
|--------------------|------|-------|
|                    | PA6  | AF1   |
|                    | PA7  | AF1   |
|                    | PA10 | AF0   |
|                    | PA11 | AF1   |
|                    | PA12 | AF0   |
|                    | PA13 | AF1   |
|                    | PA14 | AF0   |
|                    | PA15 | AF1   |
|                    | PA2  | AF2   |
|                    | PA3  | AF2   |
|                    | PA6  | AF2   |
|                    | PA7  | AF2   |
| TIM2 CHO           | PA10 | AF1   |
| TIM3_CH2           | PA11 | AF2   |
|                    | PA12 | AF1   |
|                    | PA13 | AF2   |
|                    | PA14 | AF1   |
|                    | PA15 | AF2   |

## 5.2.5.4 **UARTx alternate function I/O remapping**

## 5.2.5.4.1 UART1 alternate function I/O remapping

### Table 5-7 UART1 alternate function I/O remapping

| Alternate function | Pin  | Remap |
|--------------------|------|-------|
|                    | PA2  | AF5   |
| UART1_TX           | PA14 | AF2   |
|                    | PB0  | AF2   |
|                    | PA3  | AF5   |
| UART1_RX           | PA12 | AF2   |
|                    | PB1  | AF2   |

### 5.2.5.4.2 UART2 alternate function I/O remapping

### Table 5-8 UART2 alternate function I/O remapping

| Alternate function | Pin | Remap |
|--------------------|-----|-------|
| UART2_TX           | PA2 | AF1   |
|                    | PA8 | AF1   |
|                    | PA9 | AF1   |
|                    | PA1 | AF1   |
| UART2_RX           | PA7 | AF6   |
|                    | PA9 | AF8   |



### 5.2.5.5 I2C alternate function I/O remapping

#### Table 5-9 I2C alternate function I/O remapping

| Alternate function | Pin | Remap |
|--------------------|-----|-------|
| I2C_SCL            | PA2 | AF6   |
|                    | PA4 | AF6   |
|                    | PA9 | AF6   |
| I2C_SDA -          | PA1 | AF6   |
|                    | PA3 | AF6   |
|                    | PA5 | AF6   |
|                    | PA8 | AF6   |

### 5.2.5.6 SPI alternate function I/O remapping

#### Table 5-10 SPI alternate function I/O remapping

| Alternate function | Pin  | Remap |
|--------------------|------|-------|
|                    | PA3  | AF0   |
| SPI_NSS            | PA8  | AF5   |
| SPI_SCK            | PA14 | AF6   |
|                    | PA15 | AF0   |
| SPI_MISO           | PA7  | AF0   |
|                    | PB0  | AF6   |
| SPI_MOSI           | PA6  | AF0   |
|                    | PB1  | AF6   |

### 5.2.5.7 **COMP alternate function I/O remapping**

#### Table 5-11 COMP alternate function I/O remapping

| Alternate function | Pin | Remap |
|--------------------|-----|-------|
| COMP1_OUT          | PA8 | AF3   |

### 5.2.5.8 **BEEPER alternate function I/O remapping**

Table 5-12 BEEPER alternate function I/O remapping

| Alternate function | Pin  | Remap |
|--------------------|------|-------|
| BEEPER1_OUT        | PA14 | AF7   |
| BEEPER1_N_OUT      | PB0  | AF7   |

### 5.2.5.9 EVENTOUT alternate function I/O remapping

### Table 5-13 EVENTOUT alternate function I/O remapping

| Alternate function | Pin | Remap |
|--------------------|-----|-------|
| EVENTOUT           | PA4 | AF3   |
|                    | PB0 | AF3   |
|                    | PB1 | AF3   |



### 5.2.5.10 MCO alternate function I/O remapping

#### Table 5-14 MCO alternate function I/O remapping

| Alternate function | Pin  | Remap |
|--------------------|------|-------|
| МСО                | PA13 | AF6   |

### 5.2.5.11 ADC external IO triggers alternate function

The external trigger source for ADC conversion supports PA0~PA15 and PB0~PB1.

## 5.2.6 **I/O configuration of peripherals**

#### Table 5-15 ADC

| ADC | PAD configuration    |
|-----|----------------------|
| ADC | Analog function mode |

#### Table 5-16 TIM1

| TIM1 pin  | Configuration                  | PAD configuration mode       |
|-----------|--------------------------------|------------------------------|
|           | Input capture channel x        | Input floating               |
| TIM1_CHx  | Output compare channel x       | Push-pull alternate function |
| TIM1_CHxN | Complementary output channel x | Push-pull alternate function |
| TIM1_BKIN | Brake input                    | Input floating               |
| TIM1_ETR  | External trigger timer input   | Input floating               |

#### Table 5-17 TIM3

| TIM3 pin | Configuration                | PAD configuration mode       |
|----------|------------------------------|------------------------------|
| TIM2 CIL | Input capture channel x      | Input floating               |
| TIM3_CHx | Output compare channel x     | Push-pull alternate function |
| TIM3_ETR | External trigger timer input | Input floating               |

#### Table 5-18 UART

| UART1/2 pin | Configuration    | PAD configuration                             |
|-------------|------------------|-----------------------------------------------|
| UARTx_TX    | Full duplex mode | Push-pull alternate function                  |
|             | Half duplex mode | Push-pull alternate function                  |
| UARTx_RX    | Full duplex mode | Input floating or input + pull-up             |
|             | Half duplex mode | It is not used. It can be used as general I/O |

#### Table 5-19 I2C

| I2C pin | Configuration | PAD configuration             |
|---------|---------------|-------------------------------|
| I2C_SCL | I2C clock     | Open drain alternate function |
| I2C_SDA | I2C data      | Open drain alternate function |

#### Table 5-20 SPI

| SPI pin | Configuration | PAD configuration            |
|---------|---------------|------------------------------|
| SPI_SCK | Master mode   | Push-pull alternate function |

#### Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| SPI pin   | Configuration                            | PAD configuration                                      |
|-----------|------------------------------------------|--------------------------------------------------------|
|           | Slave mode                               | Input floating                                         |
|           | Full duplex mode/master mode             | Push-pull alternate function                           |
|           | Full duplex mode/slave mode              | Input floating or input + pull-up                      |
| SDI MOSI  | Simplex bidirectional data wire / master | Duch and alternate function                            |
| SPI_MOSI  | mode                                     | Push-pull alternate function                           |
|           | Simplex bidirectional data wire /slave   | It is not used. It can be used as general I/O          |
|           | mode                                     | It is not used. It can be used as general I/O          |
|           | Full duplex mode/ master mode            | Input floating or input + pull-up                      |
|           | Full duplex mode/slave mode              | Push-pull alternate function                           |
| SPI MISO  | Simplex bidirectional data wire /master  | It is not used. It can be used as general I/O          |
| 511_11150 | mode                                     | it is not used. It can be used as general i/O          |
|           | Simplex bidirectional data wire /slave   | Push-pull alternate function                           |
|           | mode                                     | rush-pun alternate function                            |
|           | Hardware master/slave mode               | Input floating or input + pull-up or input + pull-down |
| SPI_NSS   | Hardware master mode /NSS output is      | Push-pull alternate function (NSS can choose IDLE      |
| 511_135   | enabled                                  | high impedance or IDLE is 1 when used as host)         |
|           | Software mode                            | It is not used. It can be used as general I/O          |

#### Table 5-21 COMP

| The COMP pin | PAD configuration            |
|--------------|------------------------------|
| COMP_OUT     | Push-pull alternate function |
| COMP_IN      | Analog input                 |

#### Table 5-22 BEEPER

| BEEPER pin   | PAD configuration            |
|--------------|------------------------------|
| BEEPER_OUT   | Push-pull alternate function |
| BEEPER_N_OUT | Push-pull alternate function |

#### Table 5-23 Other

| Pin             | Alternate function       | GPIO configuration                                     |
|-----------------|--------------------------|--------------------------------------------------------|
| EVENTOUT        | Event output             | Push-pull alternate function                           |
| МСО             | Clock output             | Push-pull alternate function                           |
| EXTI line input | External interrupt input | Input floating or input + pull-up or input + pull-down |

## 5.2.7 GPIO locking mechanism

The locking mechanism allows to freeze contents of I/O configuration (GPIOx\_PMODE, GPIOx\_POTYPE, GPIOx\_PUPD, GPIOx\_DS, and GPIOx\_SR) and alternate function registers (GPIOx\_AFL and GPIOx\_AFH). When the lock program is executed on one port bit, the configuration of that port bit will no longer be changed until the next reset, referring to the port configuration lock register GPIOx\_PLOCK.

PLOCKK, that is, GPIOx\_PLOCK [16], becomes 1 only after the correct sequence w1-> w0-> w1-> r0 (r0 here is also a must). After that, it becomes 0 only if the system reset is performed. GPIOx\_PLOCK.PLOCK[15:0]



can only be modified at GPIOx\_PLOCK.PLOCKK=0.

- The lock sequence to set GPIOx\_PLOCK.PLOCKK bit, w1-> w0-> w1-> r0 will be valid only if the value (1 or 0) in GPIOx\_PLOCK.PLOCK [15:0] does not change during this sequence. The GPIOx\_PLOCK.PLOCKK bit will not be set if the value in GPIOx\_PLOCK.PLOCK [15:0] changes during this sequence.
- As long as GPIOx\_PLOCK.PLOCKK=0 and GPIOx\_PLOCK.PLOCKy = 0 or 1, all configuration and alternate function bits can be modified. When GPIOx\_PLOCK.PLOCKK=1 but GPIOx\_PLOCK.PLOCKy = 0, the corresponding configuration and alternate function bits corresponding to GPIOx\_PLOCK.PLOCKy = 0 can be modified.
- Only when GPIOx\_PLOCK.PLOCKK=1 and GPIOx\_PLOCK.PLOCKy = 1, the configurations corresponding to GPIOx\_PLOCK.PLOCKy = 1 are locked and can not be modified.
- If the lock sequence operation is wrong, then it must be redone (w1-> w0-> w1-> r0) to initiate the lock operation again.

# **5.3 GPIO registers**

These peripheral registers must be operated in 32-bit word mode.

GPIOA base address: 0x4000 1C00.

GPIOB base address: 0x4000 2000.

## 5.3.1 **GPIOA register overview**

| Offset | Register     | 31 | 30             | 29 | 28           | 27 | 26           | 25           | 24   | 23    | 22           | 21 | 20           | 19 | 18          | 17           | 16 | 15    | 14          | 13    | 12    | 11    | 10          | 6           | 8           | 7          | 9           | 5    | 4    | 3    | 2    | 1           | 0              |
|--------|--------------|----|----------------|----|--------------|----|--------------|--------------|------|-------|--------------|----|--------------|----|-------------|--------------|----|-------|-------------|-------|-------|-------|-------------|-------------|-------------|------------|-------------|------|------|------|------|-------------|----------------|
| 0x00   | GPIOA_PMODE  |    | In:I ICIERIOMA |    | PMODE14[1:0] |    | PMODE13[1:0] | DMODEL2[1-0] |      |       | PMODEI1[1:0] |    | PMODEI0[1:0] |    | PMODE9[1:0] | DAIODE901.01 |    |       | PMUDE/[1:0] |       |       |       | [0:1]carowa | BMODE1[1-0] | FMUDE4[1:0] | IN FREEDOM | PMUDE3[1:0] |      |      |      |      | BMODENT: 01 | โด:Tlnฮศกเพิ่ม |
|        | Reset value  | 1  | 1              | 1  | 1            | 1  | 1            | 1            | 1    | 1     | 1            | 1  | 1            | 1  | 0           | 1            | 0  | 1     | 1           | 1     | 1     | 1     | 1           | 1           | 1           | 1          | 1           | 1    | 1    | 1    | 1    | 1           | 1              |
| 0x04   | GPIOA_POTYPE |    |                |    |              |    |              |              | Rese | erved |              |    |              |    |             |              |    | POT15 | POT14       | POT13 | POT12 | POTII | POT10       | POT9        | POT8        | POT7       | POT6        | POT5 | POT4 | POT3 | POT2 | POT1        | POT0           |
|        | Reset value  |    |                |    |              |    |              |              |      |       |              |    |              |    |             |              |    | 0     | 0           | 0     | 0     | 0     | 0           | 0           | 0           | 0          | 0           | 0    | 0    | 0    | 0    | 0           | 0              |
| 0x08   | GPIOA_SR     |    |                |    |              |    |              |              | Rese | erved |              |    |              |    |             |              |    | SR15  | SR14        | SR13  | SR12  | SR11  | SR10        | SR9         | SR8         | SR7        | SR6         | SR5  | SR4  | SR3  | SR2  | SRI         | SR0            |
|        | Reset value  |    |                |    |              |    |              |              |      |       |              |    |              |    |             |              |    | 1     | 1           | 1     | 1     | 1     | 1           | 1           | 1           | 1          | 1           | 1    | 1    | 1    | 1    | 1           | 1              |

### Table 5-24 GPIOA register overview



www.nationstech.com

|        |             | 1     | T           | -1           | -           | -     |             | T            | -           | 1     |             |              | 1             | 1             |                |              | 1           |               |                |              |            |               |               |        |            |        |             |             |               |        |             |              |              |
|--------|-------------|-------|-------------|--------------|-------------|-------|-------------|--------------|-------------|-------|-------------|--------------|---------------|---------------|----------------|--------------|-------------|---------------|----------------|--------------|------------|---------------|---------------|--------|------------|--------|-------------|-------------|---------------|--------|-------------|--------------|--------------|
| Offset | Register    | 31    | 00          | 29<br>29     | 36          | 27    | 26          | 25           | 24          | 23    | 22          | 21           | 20            | 19            | 18             | 17           | 16          | 15            | 14             | 13           | 12         | 11            | 10            | 6      | 8          | L      | 9           | 5           | 4             | 3      | 2           | 1            | 0            |
| 0x0C   | GPIOA_PUPD  |       | PUPD15[1:0] |              | PUPD14[1:0] |       | PUPD13[1:0] |              | PUPD12[1:0] |       | [0:1]LIGAOA |              | โด: 1 โดโตสกส |               |                |              | [0:1]807404 |               |                |              | LULINI I.N |               | LULID [1:0]   |        | [0:1]#UTUY |        | [0:1]e7J0J  |             | โด:1 ไฮติสกิส |        | [0:1]10A0A  |              | FAIT 10 TO 1 |
|        | Reset value | 0     | 1           | 1            | 0           | 0     | 1           | 0            | 0           | 0     | 0           | 0            | 0             | 1             | 0              | 0            | 1           | 0             | 0              | 0            | 0          | 0             | 0             | 0      | 0          | 0      | 0           | 0           | 0             | 0      | 0           | 0            | 0            |
| 0x10   | GPIOA_PID   |       |             |              |             |       |             |              | Rese        | erved |             |              | <u> </u>      | <u> </u>      |                |              | <u> </u>    | PID15         | PID14          | PID13        | PID12      | PID11         | PID10         | 6CIId  | PID8       | LCIId  | 90IId       | 50IA        | PID4          | ECIId  | PID2        | 1 CIId       | PID0         |
|        | Reset value |       |             |              |             |       |             |              |             |       |             |              |               |               |                |              |             | 0             | 0              | 0            | 0          | 0             | 0             | 0      | 0          | 0      | 0           | 0           | 0             | 0      | 0           | 0            | 0            |
| 0x14   | GPIOA_POD   |       |             |              |             |       |             |              | Res         | erved |             |              |               |               |                |              |             | 510D4         | POD14          | £10D13       | POD12      | 11 DOJ        | POD10         | 600d   | POD8       | Laoq   | 90Dd        | 50D5        | POD4          | £0D3   | POD2        | IODA         | POD0         |
|        | Reset value |       |             |              |             |       |             |              |             |       |             |              | -             | -             |                |              | -           | 0             | 0              | 0            | 0          | 0             | 0             | 0      | 0          | 0      | 0           | 0           | 0             | 0      | 0           | 0            | 0            |
| 0x18   | GPIOA_PBSC  | PBC15 | 50C14       | PBC13        | DRC13       | PBCI1 | PBC10       | PRC9         | PBC8        | PBC7  | PBC6        | PBC5         | PBC4          | PBC3          | PBC2           | PBCI         | PBC0        | PBS15         | PBS14          | PBS13        | PBS12      | PBS11         | PBS10         | PBS9   | PBS8       | PBS7   | PBS6        | PBS5        | PBS4          | PBS3   | PBS2        | PBS1         | PBS0         |
|        | Reset value | 0     | (           | ) 0          | 0           | 0     | 0           | 0            | 0           | 0     | 0           | 0            | 0             | 0             | 0              | 0            | 0           | 0             | 0              | 0            | 0          | 0             | 0             | 0      | 0          | 0      | 0           | 0           | 0             | 0      | 0           | 0            | 0            |
| 0x28   | GPIOA_PBC   |       |             |              |             |       |             |              | Res         | erved |             |              | <u>.</u>      | <u>.</u>      |                |              | <u>.</u>    | PBC15         | PBC14          | PBC13        | PBC12      | PBC11         | PBC10         | PBC9   | PBC8       | PBC7   | PBC6        | PBC5        | PBC4          | PBC3   | PBC2        | PBC1         | PBC0         |
|        | Reset value |       |             |              |             |       |             |              |             |       |             |              |               |               |                |              |             | 0             | 0              | 0            | 0          | 0             | 0             | 0      | 0          | 0      | 0           | 0           | 0             | 0      | 0           | 0            | 0            |
| 0x1C   | GPIOA_PLOCK |       |             | I            |             |       |             | Reserv       | ed          |       |             |              |               |               |                | PLOCKK       | PLOCK15     | PLOCK14       | PLOCK13        | PLOCK12      | PLOCK11    | PLOCK10       | PLOCK9        | PLOCK8 | PLOCK7     | PLOCK6 | PLOCK5      | PLOCK4      | PLOCK3        | PLOCK2 | PLOCK1      | PLOCK0       |              |
|        | Reset value |       |             |              |             |       |             |              |             |       |             |              |               | -             |                |              | 0           | 0             | 0              | 0            | 0          | 0             | 0             | 0      | 0          | 0      | 0           | 0           | 0             | 0      | 0           | 0            | 0            |
| 0x20   | GPIOA_AFL   |       |             | AFSEL7[3:0]  |             |       |             |              |             |       | AFSEL2(U)   |              |               | A FSFT 412-01 | AF3EL4[3:0]    |              |             | A ESET 313.01 | APSEL2:0]      |              |            | A EVET 213.01 | [0:c]773644   |        |            |        | AFSEL1[5:0] |             |               |        | [o:c]ormere |              |              |
|        | Reset value | 1     | 1           | 1            | 1           | 1     | 1           | 1            | 1           | 1     | 1           | 1            | 1             | 1             | 1              | 1            | 1           | 1             | 1              | 1            | 1          | 1             | 1             | 1      | 1          | 1      | 1           | 1           | 1             | 1      | 1           | 1            | 1            |
| 0x24   | GPIOA_AFH   |       |             | AFSEL15[3:0] |             |       |             | AFSEL14[3:0] |             |       |             | AFSEL15[3:0] |               |               | 10.5101 1393 A | AFSEL12[5:0] |             |               | A EGET 1112-01 | AFSEL11[3:0] |            |               | AESEL 1003-01 |        |            |        |             | AFSEL9[5:0] |               |        |             | [n:clorac.tv |              |
|        | Reset value | 1     | 1           | 1            | 1           | 1     | 1           | 1            | 1           | 1     | 1           | 1            | 1             | 1             | 1              | 1            | 1           | 1             | 1              | 1            | 1          | 1             | 1             | 1      | 1          | 0      | 0           | 0           | 0             | 0      | 0           | 0            | 0            |
|        |             |       | -           |              | -           |       |             | -            |             | _     |             |              | _             | _             |                |              | -           |               |                | _            |            | _             | _             |        |            | -      |             | -           | -             | -      |             | -            |              |

### Nations Technologies Inc.

Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| Offset | Register    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15   | 14   | 13   | 12   | 11   | 10   | 6   | 8   | 7   | 9   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-------------|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 0x2C   | GPIOA_DS    |    |    |    |    |    |    |    | Rese | rved |    |    |    |    |    |    |    | DS15 | DS14 | DS13 | DS12 | DS11 | DS10 | DS9 | DS8 | DS7 | DS6 | DS5 | DS4 | DS3 | DS2 | DS1 | DS0 |
|        | Reset value |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    | 0    | 0    | 0    | 0    | 0    | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

# 5.3.2 **GPIOB register overview**

## Table 5-25 GPIOB register overview

| Offset | Register     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17      | 16    | 15 | 14 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | ç           | 1    | 0             |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------|------|---------------|
| 0x00   | GPIOA_PMODE  |    |    |    |    |    |    |    |    |    |    |    |    |    | Re | eserved |       |    |    |    |    |    |    |   |   |   |   |   |   |   | PMODEI[1:0] |      |               |
|        | Reset value  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |       |    |    |    |    |    |    |   |   |   |   |   |   | 1 | 1           | 1    | 1             |
| 0x04   | GPIOA_POTYPE |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Res     | erved |    |    |    |    |    |    |   |   |   |   |   |   |   |             | POTI | POT0          |
|        | Reset value  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |       |    |    |    |    |    |    |   |   |   |   |   |   |   |             | 0    | 0             |
| 0x08   | GPIOA_SR     |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Res     | erved |    |    |    |    |    |    |   |   |   |   |   |   |   |             | SR1  | SR0           |
|        | Reset value  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |       |    |    |    |    |    |    |   |   |   |   |   |   |   |             | 1    | 1             |
| 0x0C   | GPIOA_PUPD   |    |    |    |    |    |    |    |    |    |    |    |    |    | Re | eserved |       |    |    |    |    |    |    |   |   |   |   |   |   |   | PUPD1[1:0]  |      | In the second |
|        | Reset value  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |       |    |    |    |    |    |    |   |   |   |   |   |   | 0 | C           | ) 0  | 0             |
| 0x10   | GPIOA_PID    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Res     | erved |    |    |    |    |    |    |   |   |   |   |   |   |   |             | PIDI | PID0          |
|        | Reset value  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |       |    |    |    |    |    |    |   |   |   |   |   |   |   |             | 0    | 0             |
| 0x14   | GPIOA_POD    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Res     | erved |    |    |    |    |    |    |   |   |   |   |   |   |   |             | POD1 | POD0          |
|        | Reset value  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |       |    |    |    |    |    |    |   |   |   |   |   |   |   |             | 0    | 0             |

#### Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| Offset | Register    | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24     | 23 | 22 | 21 | 20   | 19    | 18 | 17   | 16     | 15 | 14 | 13 | 12 | 11 | 10 | 6    | 8     | 7 | 9 | 5           | 4 | 3 | 2           | 1      | 0      |
|--------|-------------|----|----|----|----|----|----|------|--------|----|----|----|------|-------|----|------|--------|----|----|----|----|----|----|------|-------|---|---|-------------|---|---|-------------|--------|--------|
| 0x18   | GPIOA_PBSC  |    |    |    |    |    |    | Rese | erved  |    |    |    |      |       |    | PBCI | PBC0   |    |    |    |    |    |    | Rese | erved |   |   |             |   |   |             | ISBI   | PBS0   |
|        | Reset value |    |    |    |    |    |    |      |        |    |    |    |      |       |    | 0    | 0      |    |    |    |    |    |    |      |       |   |   |             |   |   |             | 0      | 0      |
| 0x28   | GPIOA_PBC   |    |    |    |    |    |    |      |        |    |    |    |      |       |    | Rese | erved  |    |    |    |    |    |    |      |       |   |   |             |   |   |             | PBC1   | PBC0   |
|        | Reset value |    |    |    |    |    |    |      |        |    |    |    |      |       |    |      |        |    |    |    |    |    |    |      |       |   |   |             |   |   |             | 0      | 0      |
| 0x1C   | GPIOA_PLOCK |    |    |    |    |    |    | R    | eserve | ed |    |    |      |       |    |      | PLOCKK |    |    |    |    |    |    | Rese | erved |   |   |             |   |   |             | PLOCK1 | PLOCK0 |
|        | Reset value |    |    |    |    |    |    |      |        |    |    |    |      |       |    |      | 0      |    |    |    |    |    |    |      |       |   |   |             |   |   |             | 0      | 0      |
| 0x20   | GPIOA_AFL   |    |    |    |    |    |    |      |        |    |    |    | Rese | ervec | d  |      |        |    |    |    |    |    |    |      |       |   |   | AFSEL1[3:0] |   |   | AFSFL013-01 |        |        |
|        | Reset value |    |    |    |    |    |    |      |        |    |    |    |      |       |    |      |        |    |    |    |    |    |    |      |       | 1 | 1 | 1           | 1 | 1 | 1           | 1      | 1      |
| 0x2C   | GPIOA_DS    |    |    |    |    |    |    |      |        |    |    |    |      |       |    | Rese | rved   |    |    |    |    |    |    |      |       |   |   |             |   |   |             | ISC    | DS0    |
|        | Reset value |    |    |    |    |    |    |      |        |    |    |    |      |       |    |      |        |    |    |    |    |    |    |      |       |   |   |             |   |   |             | 0      | 0      |

# 5.3.3 **GPIO port mode register (GPIOx\_PMODE)**

Address offset: 0x00

Reset value(Port A) : 0xFFFA FFFF

| 31   | 30       | 29   | 28       | 27   | 26               | 25   | 24       | 23    | 22       | 21    | 20       | 19   | 18           | 17   | 16      |
|------|----------|------|----------|------|------------------|------|----------|-------|----------|-------|----------|------|--------------|------|---------|
| PMOD | E15[1:0] | PMOD | E14[1:0] | PMOD | '<br>E13[1:0]    | PMOD | E12[1:0] | PMODI | 811[1:0] | PMODI | E10[1:0] | PMOD | '<br>E9[1:0] | PMOD | E8[1:0] |
|      | L        |      | L        |      | L                |      | L        |       |          |       |          |      | L            |      |         |
| r    | w        | r    | w        | r    | w                | r    | W        | r     | v        | r     | w        | r    | w            | rv   | N       |
| 15   | 14       | 13   | 12       | 11   | 10 9 8 7 6 5 4 3 | 2    | 1        | 0     |          |       |          |      |              |      |         |
| PMOD | E7[1:0]  | PMOD | E6[1:0]  | PMOD | E5[1:0]          | PMOD | E4[1:0]  | PMOD  | E3[1:0]  | PMOD  | E2[1:0]  | PMOD | E1[1:0]      | PMOD | E0[1:0] |
| r    | w        | r    | w        | r    | w                | r    | w        | r     | v        | r     | w        | r    | w            | ľ    | N       |

| Bit field | Name         | Description                            |
|-----------|--------------|----------------------------------------|
| 31:30     | PMODEy [1:0] | Mode bits y for port GPIOx $(x = A,B)$ |
| 29:28     |              | 00: Input mode                         |
| 27:26     |              | 01: General purpose output mode        |



| Bit field | Name | Description                     |
|-----------|------|---------------------------------|
| 25:24     |      | 10: Alternate function mode     |
| 23:22     |      | 11: Analog function mode        |
| 21:20     |      | <i>Note:</i> $x = A, y = 015$ . |
| 19:18     |      | x = B, y = 0, I.                |
| 17:16     |      |                                 |
| 15:14     |      |                                 |
| 13:12     |      |                                 |
| 11:10     |      |                                 |
| 9:8       |      |                                 |
| 7:6       |      |                                 |
| 5:4       |      |                                 |
| 3:2       |      |                                 |
| 1:0       |      |                                 |

# 5.3.4 **GPIO port type register (GPIOx\_POTYPE)**

Address offset: 0x04

Reset value (Port A) : 0x0000 0000

Reset value (Port B) : 0x0000 0000

| 31    |       |       |       |       |       |      |      |      |      |      |      |      |      |      | 16   |
|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
|       | •     | •     |       |       | I.    |      | Rese | rved |      | 1    | I    |      |      | I    |      |
|       | 1     | 1     | 1     |       |       |      | 1    | 1    |      | 1    |      |      | 1    | 1    |      |
| 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| POT15 | POT14 | POT13 | POT12 | POT11 | POT10 | РОТ9 | POT8 | POT7 | POT6 | POT5 | POT4 | POT3 | POT2 | POT1 | РОТ0 |
| rw    | rw    | rw    | rw    | rw    | rw    | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   |

| Bit Field | Name     | Description                                   |
|-----------|----------|-----------------------------------------------|
| 31:16     | Reserved | The reset value must be maintained.           |
| 15:0      | РОТу     | Output mode bits y for port GPIOx $(x = A,B)$ |
|           |          | 0: Output push-pull mode                      |
|           |          | 1: Output open-drain mode                     |
|           |          | <i>Note:</i> $x = A$ , $y = 015$ .            |
|           |          | x = B, y = 0, I.                              |

# 5.3.5 **GPIO slew rate register (GPIOx\_SR)**

Address offset: 0x08

Reset value (Port A) : 0x0000 FFFF



| 31   |      |      |      |      |      |     |      |      |     |     |     |     |     |     | 16  |
|------|------|------|------|------|------|-----|------|------|-----|-----|-----|-----|-----|-----|-----|
|      | 1    | 1    | 1    |      | 1    | I   | Rese | rved | I   | I   | 1   | I   |     | I   |     |
|      | 1    | I    | 1    | 1    | 1    | 1   | 1    | 1    | 1   | 1   | 1   | 1   | 1   | 1   |     |
| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8    | 7    | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| SR15 | SR14 | SR13 | SR12 | SR11 | SR10 | SR9 | SR8  | SR7  | SR6 | SR5 | SR4 | SR3 | SR2 | SR1 | SR0 |
|      |      |      |      |      |      |     |      |      |     |     |     |     |     |     |     |
| rw   | rw   | rw   | rw   | rw   | rw   | rw  | rw   | rw   | rw  | rw  | rw  | rw  | rw  | rw  | rw  |

| Bit Field  | Name     | Description                                                 |  |
|------------|----------|-------------------------------------------------------------|--|
| Caused the | Reserved | The reset value must be maintained.                         |  |
| 15:0       | SRy      | Slew rate configuration bits y for port GPIOx $(x = A,B)$ : |  |
|            |          | 0: Fast slew rate                                           |  |
|            |          | 1: Slow slew rate                                           |  |
|            |          | <i>Note:</i> $x = A$ , $y = 015$ .                          |  |
|            |          | x = B, y = 0, 1.                                            |  |

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

Address offset: 0x0C

Reset value (Port A) : 0x0009 0000

| 31       | 30    | 29      | 28      | 27        | 26      | 25     | 24      | 23       | 22      | 21      | 20     | 19     | 18      | 17   | 16     |
|----------|-------|---------|---------|-----------|---------|--------|---------|----------|---------|---------|--------|--------|---------|------|--------|
| PUPD15   | [1:0] | PUPD    | 14[1:0] | PUPD      | 13[1:0] | PUPD   | 12[1:0] | PUPD     | 11[1:0] | PUPD    | 0[1:0] | PUPD   | 9[1:0]  | PUPD | 8[1:0] |
| rw<br>15 | 14    | r<br>13 | w 12    | . r<br>11 | w 10    | r<br>9 | w 8     | . r<br>7 | w 6     | rv<br>5 | v 4    | r<br>3 | w 2     | . r  | w O    |
| PUPD7[   | 1:0]  | PUPD    |         | PUPE      | 95[1:0] | PUPD   | 94[1:0] | PUPE     | 3[1:0]  | PUPD    | 2[1:0] | PUPD   | 01[1:0] | PUPD | 0[1:0] |
| rw       |       | r       | w       | r         | w       | r      | w       | r        | w       | rv      | v      | r      | w       | r    | w      |

| Bit Field | Name       | Description                                                 |  |
|-----------|------------|-------------------------------------------------------------|--|
| 31:30     | PUPDy[1:0] | Pull-up/pull-down mode bits y for port GPIOx ( $x = A,B$ ): |  |
| 29:28     |            | 00: No pull-up, pull-down                                   |  |
| 27:26     |            | 01: Pull-up                                                 |  |
| 25:24     |            | 10: Pull-down                                               |  |
| 23:22     |            | 11: Reserved                                                |  |
| 21:20     |            | <i>Note:</i> $x = A$ , $y = 015$ .                          |  |
| 19:18     |            | x = B, y = 0, 1.                                            |  |
| 17:16     |            |                                                             |  |
| 15:14     |            |                                                             |  |
| 13:12     |            |                                                             |  |
| 11:10     |            |                                                             |  |
| 9:8       |            |                                                             |  |
| 7:6       |            |                                                             |  |
| 5:4       |            |                                                             |  |
| 3:2       |            |                                                             |  |



| Bit Field | Name | Description |
|-----------|------|-------------|
| 1:0       |      |             |

## 5.3.7 **GPIO port input data register (GPIOx\_PID)**

Address offset: 0x10

Reset value (Port A) : 0x0000 0000

Reset value (Port B) : 0x0000 0000

| 31    |       |       |       |       |       |      |      |      |      |      |      |      |      |      | 16   |
|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
|       |       |       |       |       |       |      | Rese | rved |      |      |      |      |      |      |      |
| 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| PID15 | PID14 | PID13 | PID12 | PID11 | PID10 | PID9 | PID8 | PID7 | PID6 | PID5 | PID4 | PID3 | PID2 | PID1 | PID0 |
| r     | r     | r     | r     | r     | r     | r    | r    | r    | r    | r    | r    | r    | r    | r    | r    |

| Bit Field | Name     | Description                                                                           |
|-----------|----------|---------------------------------------------------------------------------------------|
| 31:16     | Reserved | The reset value must be maintained.                                                   |
| 15:0      | PIDy     | Port GPIOx input data ( $x = A,B$ ):                                                  |
|           |          | These bits are read-only. They contain the input value of the corresponding I/O port. |
|           |          | <i>Note:</i> $x = A$ , $y = 015$ .                                                    |
|           |          | x = B, y = 0, 1.                                                                      |

# 5.3.8 **GPIO port output data register (GPIOx\_POD)**

Address offset: 0x14

Reset value (Port A) : 0x0000 0000

| 31    |       |       |       |       |       |      |      |      |      |      |      |      |      |      | 16   |
|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
|       | •     | •     | •     | •     |       |      | Rese | rved |      | •    | •    | •    |      |      |      |
|       |       | 1     | 1     | I     | 1     |      | 1    |      | 1    | I    | 1    | I    | I    |      | I    |
| 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| POD15 | POD14 | POD13 | POD12 | POD11 | POD10 | POD9 | POD8 | POD7 | POD6 | POD5 | POD4 | POD3 | POD2 | POD1 | POD0 |
| rw    | rw    | rw    | rw    | rw    | rw    | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   |

| Bit Field | Name     | Description                                                                         |
|-----------|----------|-------------------------------------------------------------------------------------|
| 31:16     | Reserved | The reset value must be maintained.                                                 |
| 15:0      | PODy     | Port output data                                                                    |
|           |          | These bits can be read and written by software. Port output data, the corresponding |
|           |          | POD bits can be independently set/cleared by GPIOx_PBSC ( $x = A,B$ ) register.     |
|           |          | <i>Note:</i> $x = A$ , $y = 015$ .                                                  |
|           |          | x = B, y = 0, I.                                                                    |



# 5.3.9 GPIO port bit set/clear register (GPIOx\_PBSC)

Address offset: 0x18

Reset value (Port A) : 0x0000 0000

Reset value (Port B) : 0x0000 0000

| 31      | 30      | 29      | 28      | 27      | 26      | 25     | 24     | 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
|---------|---------|---------|---------|---------|---------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| PBC15   | PBC14   | PBC13   | PBC12   | PBC11   | PBC10   | PBC9   | PBC8   | PBC7   | PBC6   | PBC5   | PBC4   | PBC3   | PBC2   | PBC1   | PBC0   |
| w<br>15 | w<br>14 | w<br>13 | w<br>12 | w<br>11 | w<br>10 | w<br>9 | w<br>8 | w<br>7 | w<br>6 | w<br>5 | w<br>4 | w<br>3 | w<br>2 | w<br>1 | w<br>0 |
| PBS15   | PBS14   | PBS13   | PBS12   | PBS11   | PBS10   | PBS9   | PBS8   | PBS7   | PBS6   | PBS5   | PBS4   | PBS3   | PBS2   | PBS1   | PBS0   |
| w       | w       | w       | w       | w       | w       | w      | w      | w      | w      | w      | w      | w      | w      | w      | w      |

| Bit Field | Name | Description                                                                    |
|-----------|------|--------------------------------------------------------------------------------|
| 31:16     | РВСу | Clear bit y of port GPIOx $(x = A,B)$                                          |
|           |      | These bits can only be written.                                                |
|           |      | 0: The corresponding GPIOx_POD.PODy bit is not affected                        |
|           |      | 1: Clears the corresponding GPIOx_POD.PODy bit to 0                            |
|           |      | Note: If the corresponding bits of PBSy and PBCy are set at the same time, the |
|           |      | PBSy bits take effect.                                                         |
|           |      | <i>Note:</i> $x = A$ , $y = 015$ .                                             |
|           |      | x = B, y = 0, I.                                                               |
| 15:0      | PBSy | Set bit y of port GPIOx ( $x = A,B$ )                                          |
|           |      | These bits can only be written.                                                |
|           |      | 0: The corresponding GPIOx_POD.PODy bit is not affected                        |
|           |      | 1: Sets the corresponding GPIOx_POD.PODy bit to 1                              |
|           |      | <i>Note:</i> $x = A, B, y = 015$ .                                             |
|           |      | x = B, y = 0, 1.                                                               |

## 5.3.10 GPIO port bit clear register (GPIOx\_PBC)

Address offset: 0x28

Reset value (Port A) : 0x0000 0000

| 31    |       |       |       |       |       |      |      |      |      |      |      |      |      |      | 16   |
|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
|       | •     |       | I     | I     |       |      | Rese | rved | I    | I    | 1    |      | I    |      | '    |
|       | I     |       | I     | I     |       | I    |      |      | I    |      | I    | L    |      |      |      |
| 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| PBC15 | PBC14 | PBC13 | PBC12 | PBC11 | PBC10 | PBC9 | PBC8 | PBC7 | PBC6 | PBC5 | PBC4 | PBC3 | PBC2 | PBC1 | PBC0 |
| w     | w     | w     | w     | w     | w     | w    | w    | W    | w    | w    | w    | w    | w    | W    | w    |

| Bit Field | Name     | Description                         |
|-----------|----------|-------------------------------------|
| 31:16     | Reserved | The reset value must be maintained. |



| Bit Field | Name | Description                                             |
|-----------|------|---------------------------------------------------------|
| 15:0      | РВСу | Clear bit y of port GPIOx $(x = A,B)$                   |
|           |      | These bits can only be written.                         |
|           |      | 0: The corresponding GPIOx_POD.PODy bit is not affected |
|           |      | 1: Clears the corresponding GPIOx_POD.PODy bit to 0     |
|           |      | <i>Note:</i> $x = A$ , $y = 015$ .                      |
|           |      | x = B, y = 0, 1.                                        |

# 5.3.11 GPIO port lock register (GPIOx\_PLOCK)

Address offset: 0x1C

Reset value (Port A) : 0x0000 0000



| Bit Field | Name     | Description                                                                          |
|-----------|----------|--------------------------------------------------------------------------------------|
| 31:17     | Reserved | The reset value must be maintained.                                                  |
| 16        | PLOCKK   | Lock key                                                                             |
|           |          | This bit can be read anytime. It can only be modified using the lock key writing     |
|           |          | sequence.                                                                            |
|           |          | 0: Port configuration lock key not active                                            |
|           |          | 1: Port configuration lock key active. GPIOx_PLOCK register is locked until an MCU   |
|           |          | reset occurs.                                                                        |
|           |          | Lock key writing sequence:                                                           |
|           |          | Write 1 -> write 0 -> write 1 -> read 0 -> read 1                                    |
|           |          | The last reading can be omitted, but it can be used to confirm that the lock key has |
|           |          | been activated.                                                                      |
|           |          | Note: During the lock key writing sequence, the value of PLOCK[15:0] must not        |
|           |          | change. Any error in the lock sequence will abort the lock.                          |
| 15:0      | PLOCKy   | Configuration lock bit y of port GPIOx $(x = A,B)$                                   |
|           |          | These bits are readable and writable but can only be written when the PLOCKK bit is  |
|           |          | 0.                                                                                   |
|           |          | 0: Do not lock the configuration of the port                                         |
|           |          | 1: Lock the configuration of the port                                                |
|           |          | <i>Note:</i> $x = A$ , $y = 015$ .                                                   |
|           |          | x = B, y = 0, 1.                                                                     |



# 5.3.12 GPIO alternate function low register (GPIOx\_AFL)

Address offset: 0x20

Reset value (Port A) : 0xFFFF FFFF

Reset value (Port B) : 0x0000 00FF

| 31 |      |         | 28 | 27 |       |         | 24 | 23 |             | 20 | 19 |       |         | 16 |
|----|------|---------|----|----|-------|---------|----|----|-------------|----|----|-------|---------|----|
|    | AFSE |         |    |    | AFSEI |         | ,  |    | AFSEL5[3:0] | 1  |    | AFSEI | .4[3:0] | .  |
|    | r    | w       |    |    | rv    | w       |    |    | rw          |    |    | r     | w       |    |
| 15 |      |         | 12 | 11 |       |         | 8  | 7  |             | 4  | 3  |       |         | 0  |
| 15 | AFSE | .3[3:0] | 12 | 11 | AFSEI | _2[3:0] | 8  | 7  | AFSEL1[3:0] | 4  | 3  | AFSEI | .0[3:0] | 0  |

| Bit Field | Name        | Description                                                        |
|-----------|-------------|--------------------------------------------------------------------|
| 31:28     | AFSELy[3:0] | Alternate function configuration bits y for port GPIOx $(x = A,B)$ |
| 27:24     |             | 0000: AF0                                                          |
| 23:20     |             | 0001: AF1                                                          |
| 19:16     |             | 0010: AF2                                                          |
| 15:12     |             | 0011: AF3                                                          |
| 11:8      |             | 0100: AF4                                                          |
| 7:4       |             | 0101: AF5                                                          |
| 3:0       |             | 0110: AF6                                                          |
|           |             | 0111: AF7                                                          |
|           |             | 1000: AF8                                                          |
|           |             | 1001: AF9                                                          |
|           |             | 1010: AF10                                                         |
|           |             | 1011: AF11                                                         |
|           |             | 1100: AF12                                                         |
|           |             | 1101: AF13                                                         |
|           |             | 1110: AF14                                                         |
|           |             | 1111: AF15                                                         |
|           |             | <i>Note:</i> $x = A$ , $y = 07$ .                                  |
|           |             | x = B, y = 0, 1.                                                   |

## 5.3.13 GPIO alternate function high register (GPIOx\_AFH)

Address offset: 0x24

Reset value (Port A) : 0xFFFF FF00



| 31 |       |          | 28 | 27 |       |         | 24 | 23 |       |         | 20 | 19 |       |          | 16 |
|----|-------|----------|----|----|-------|---------|----|----|-------|---------|----|----|-------|----------|----|
|    | AFSEL | .15[3:0] | 1  |    | AFSEL | 14[3:0] | 1  |    | AFSEL | 13[3:0] |    |    | AFSEL | .12[3:0] | 1  |
|    | r     | w        |    |    | rv    | w       |    |    | rv    | N       |    |    | r     | w        |    |
| 15 |       |          | 12 | 11 | -     |         | 8  | 7  | -     |         | 4  | 3  | -     |          | 0  |
| 15 | ı     | .11[3:0] | 12 | 11 | AFSEL |         | 8  | 7  | AFSEI |         | 4  | 3  | 1     | _8[3:0]  | 0  |

| Bit Field | Name        | Description                                                          |
|-----------|-------------|----------------------------------------------------------------------|
| 31:28     | AFSELy[3:0] | Alternate function configuration bits y for port GPIOA ( $y = 815$ ) |
| 27:24     |             | 0000: AF0                                                            |
| 23:20     |             | 0001: AF1                                                            |
| 19:16     |             | 0010: AF2                                                            |
| 15:12     |             | 0011: AF3                                                            |
| 11:8      |             | 0100: AF4                                                            |
| 7:4       |             | 0101: AF5                                                            |
| 3:0       |             | 0110: AF6                                                            |
|           |             | 0111: AF7                                                            |
|           |             | 1000: AF8                                                            |
|           |             | 1001: AF9                                                            |
|           |             | 1010: AF10                                                           |
|           |             | 1011: AF11                                                           |
|           |             | 1100: AF12                                                           |
|           |             | 1101: AF13                                                           |
|           |             | 1110: AF14                                                           |
|           |             | 1111: AF15                                                           |

# 5.3.14 GPIO driver strength register (GPIOx\_DS)

Address offset: 0x2C

Reset value (Port A) : 0x0000 0000

Reset value (Port B) : 0x0000 0000

| _ | 31   |      |      |      |      |      |     |      |      |     |     |     |     |     |     | 16  |
|---|------|------|------|------|------|------|-----|------|------|-----|-----|-----|-----|-----|-----|-----|
|   |      | 1    | 1    |      |      |      |     | Rese | rved |     |     | 1   |     |     |     |     |
| L |      | I    | I    | 1    | I    | 1    | I   | I    | I    | 1   | 1   | I   | 1   |     |     |     |
| _ | 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8    | 7    | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|   | DS15 | DS14 | DS13 | DS12 | DS11 | DS10 | DS9 | DS8  | DS7  | DS6 | DS5 | DS4 | DS3 | DS2 | DS1 | DS0 |
|   | rw   | rw   | rw   | rw   | rw   | rw   | rw  | rw   | rw   | rw  | rw  | rw  | rw  | rw  | rw  | rw  |

| Bit Field | Name     | Description                                                    |
|-----------|----------|----------------------------------------------------------------|
| 31:16     | Reserved | The reset value must be maintained.                            |
| 15:0      | DSy      | Port GPIOx drive capability configuration bits $y (x = A,B)$ : |
|           |          | 0: High drive capacity (16mA(5V)/8mA(3.3V)/4mA(2V))            |
|           |          | 1: Low drive capacity (8mA(5V)/4mA(3.3V)/2mA(2V)               |

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| Bit Field | Name | Description                        |
|-----------|------|------------------------------------|
|           |      | <i>Note:</i> $x = A$ , $y = 015$ . |
|           |      | x = B, y = 0, I.                   |

# **5.4 AFIO registers**

# 5.4.1 **AFIO register overview**

AFIO base address: 0x4000 1400

#### Table 5-26 AFIO register overview

| Offset | Register    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9       | 5           | 4 | 3    | 2     | 1      | 0 |
|--------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---------|-------------|---|------|-------|--------|---|
| 0x00   | AFIO_CFG    |    |    |    |    |    |    |    |    |    |    |    | R  | eserve | ed |    |    |    |    |    |    |    |    |   |   |   | SPI_NSS | TIM3CH2_MAP |   | EXTI | I_SEL | .[4:0] |   |
|        | Reset Value |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   | 0       | 0           | 0 | 0    | 0     | 0      | 0 |

# 5.4.2 AFIO configuration register (AFIO\_CFG)

Address offset: 0x00

Reset value: 0x0000 0000



| Bit Field | Name           | Description                                                              |
|-----------|----------------|--------------------------------------------------------------------------|
| 31:7      | Reserved       | The reset value must be maintained.                                      |
| 6         | SPI_NSS        | NSS mode of SPI (when NSS is configured as AFIO push-pull mode).         |
|           |                | 0: NSS will be high-z when idle                                          |
|           |                | 1: NSS will be high level when idle                                      |
| 5         | TIM3CH2_MAP    | TIM3 channel2 internal remap                                             |
|           |                | Set and cleared by software. This bit controls the TIM3_CH2 internal     |
|           |                | mapping.                                                                 |
|           |                | 0: The TIM3_CH2 is connected to PA2/PA3/PA6/PA7/PA10~PA15.               |
|           |                | 1: The LSI internal clock is connected to TIM3_CH2 input for calibration |
|           |                | purpose.                                                                 |
|           |                | Note: This bit is available only in high density value line devices.     |
| 4:0       | EXTI_ETRR[4:0] | Select an external pin to trigger the ADC regular conversion.            |
|           |                | 00000: Select PA0 to trigger the conversion                              |

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China





| Bit Field | Name | Description                                  |
|-----------|------|----------------------------------------------|
|           |      | 00001: Select PA1 to trigger the conversion  |
|           |      | 00010: Select PA2 to trigger the conversion  |
|           |      | 00011: Select PA3 to trigger the conversion  |
|           |      | 00100: Select PA4 to trigger the conversion  |
|           |      | 00101: Select PA5 to trigger the conversion  |
|           |      | 00110: Select PA6 to trigger the conversion  |
|           |      | 00111: Select PA7 to trigger the conversion  |
|           |      | 01000: Select PA8 to trigger the conversion  |
|           |      | 01001: Select PA9 to trigger the conversion  |
|           |      | 01010: Select PA10 to trigger the conversion |
|           |      | 01011: Select PA11 to trigger the conversion |
|           |      | 01100: Select PA12 to trigger the conversion |
|           |      | 01101: Select PA13 to trigger the conversion |
|           |      | 01110: Select PA14 to trigger the conversion |
|           |      | 01111: Select PA15 to trigger the conversion |
|           |      | 10000: Select PB0 to trigger the conversion  |
|           |      | 10001: Select PB1 to trigger the conversion  |



# **6** Interrupts and events

# **6.1 Nested vectored interrupt controller**

### Features

- 16 maskable interrupt channels (not including 16 Cortex<sup>®</sup>-M0 interrupt line);
- 4 programmable priorities (using 2 bit interrupt priorities);
- Low latency exception and interrupt handling;
- Power management control;
- The realization of system control register;

The Nested Vector Interrupt Controller (NVIC) is closely linked to the processor core, enabling low latency interrupt processing and efficient processing of late interrupts. The nested vector interrupt controller manages interrupts including core exceptions.

## 6.1.1 SysTick calibration value register

The system tick calibration value is fixed at 6000. When the system tick clock is set to 6MHz (when clock source is HCLK/8), 1 ms time reference is generated.

## 6.1.2 Interrupt and exception vectors.

| Position | Priority | Priority type | Name      | Description                                                                                  | Address     |
|----------|----------|---------------|-----------|----------------------------------------------------------------------------------------------|-------------|
| -        | -        | -             | -         | Reserved                                                                                     | 0x0000 0000 |
| -        | -3       | Fixed         | Reset     | Reset                                                                                        | 0x0000 0004 |
| -        | -2       | Fixed         | NMI       | Non-maskable interrupt.RCC clock<br>security system (CSS) is connected to<br>the NMI vector. | 0x0000 0008 |
| -        | -1       | Fixed         | HardFault | All types of errors (fault)                                                                  | 0x0000 000C |
| -        | 3        | Settable      | SVCall    | System services invoked by SWI directives                                                    | 0x0000 002C |
| -        | 5        | Settable      | PendSV    | System service requests that can be pending                                                  | 0x0000 0038 |
| -        | 6        | Settable      | SysTick   | System tick timer                                                                            | 0x0000 003C |
| 0        | 7        | Settable      | PVD       | PVD interrupt (connected to EXTI line 18)                                                    | 0x0000 0040 |
| 1        | 8        | Settable      | FLASH     | Flash global interrupt                                                                       | 0x0000 0044 |
| 2        | 9        | Settable      | EXTI0_1   | EXTI line [1:0] is interrupted                                                               | 0x0000 0048 |

### Table 6-1 Vector table



| Position | Priority | Priority type | Name                | Description                                              | Address     |
|----------|----------|---------------|---------------------|----------------------------------------------------------|-------------|
| 3        | 10       | Settable      | EXTI2_3             | EXTI line [3:2] is interrupted                           | 0x0000 004C |
| 4        | 11       | Settable      | EXTI4_17            | EXTI line [17:4] interrupt                               | 0x0000 0050 |
| 5        | 12       | Settable      | TIM1_BRK_UP_TRG_COM | TIM1 break, updates, trigger and communication interrupt | 0x0000 0054 |
| 6        | 13       | Settable      | TIM1_CC             | TIM1 capture compare interrupt                           | 0x0000 0058 |
| 7        | 14       | Settable      | TIM3                | TIM3 global interrupt                                    | 0x0000 005C |
| 8        | 15       | Settable      | TIM6                | TIM6 global interrupt (connected to EXTI line 19)        | 0x0000 0060 |
| 9        | 16       | Settable      | ADC                 | ADC global interrupt                                     | 0x0000 0064 |
| 10       | 17       | Settable      | I2C_EV              | I2C event interrupt                                      | 0x0000 0068 |
| 11       | 18       | Settable      | I2C_ER              | I2C error interrupt                                      | 0x0000 006C |
| 12       | 19       | Settable      | SPI                 | SPI global interrupt                                     | 0x0000 0070 |
| 13       | 20       | Settable      | UART1               | UART1 global interrupt                                   | 0x0000 0074 |
| 14       | 21       | Settable      | UART2               | UART2 global interrupt                                   | 0x0000 0078 |
| 15       | 22       | Settable      | COMP                | COMP global interrupt                                    | 0x0000 007C |

# 6.2 External interrupt/event controller (EXTI)

## 6.2.1 Introduction

The external interrupt/event controller contains 20 edge detection circuits that generate interrupt/event triggers. Each input line can be independently configured with pulse or pending input types, and three trigger event types including rising edge, falling edge or double edge, which can also be independently shielded. Interrupt requests that hold the state line in the pending register can be cleared by writing '1' in the corresponding bit of the pending register.

## 6.2.2 Main features

The main features of EXTI controller are as follows:

- Supports 20 software interrupt/event requests
- Interrupts/events corresponding to each input line can be configured to trigger or mask independently
- Each interrupt line has an independent state bit
- Support for pulse or pending input types
- 3 trigger events are supported: rising edge, falling edge, and double edge
- Can wake up to exit low power mode





#### Figure 6-1 Extenal interrupt/event controller block diagram

## 6.2.3 Functional description

EXTI contains 20 interrupts, 18 from I/O pins and 2 from internal modules. To generate interrupts, the NVIC interrupt channel of the external interrupt controller must be configured to enable the corresponding interrupt line. Select rising edge, falling edge, or double edge trigger event types by edge trigger configuration registers EXTI\_RT\_CFG and EXTI\_FT\_CFG, and write '1' to the corresponding bit of interrupt masking register EXTI\_IMASK to allow interrupt requests. When a preset edge trigger polarity is detected on the external interrupt line, an interrupt request is generated and the corresponding bit is set to '1'. Writing '1' to the corresponding bit of the pending register clears the interrupt request.

To generate events, the corresponding event line must be configured and enabled. According to the desired edge detection polarity, set up the rise/fall edge trigger configuration register, while writing '1' in the corresponding bit of the event masking register to allow interrupt requests. When a preset edge occurs on an event line, an event request pulse is generated and the corresponding pending bit is not set to '1'.

In addition, interrupt/event requests can also be generated by software by writing a '1' in the software interrupt/event register.



- Hardware interrupt configuration, select and configure 20 lines as interrupt sources as required:
  - Configure the mask bit (EXTI\_IMASK) for 20 interrupt lines.
  - Configure the trigger configuration bits for the selected interrupt line(EXTI\_RT\_CFG and EXTI\_FT\_CFG);
  - Configure the enable and mask bits of the NVIC interrupt channel corresponding to the external interrupt controller so that the requests in the 20 interrupt lines can be correctly responded.
- Hardware event configuration: Select 20 lines as event sources as required:
  - Configure the mask bit (EXTI\_EMASK) for 20 event lines.
  - Configure the trigger configuration bits for the selected event line (EXTI\_RT\_CFG and EXTI\_FT\_CFG).
- Software interrupt/event configuration, select 20 lines as software interrupt/event lines as required:
  - Configure 20 interrupt/event line mask bits (EXTI\_IMASK and EXTI\_EMASK).
  - Configure the request bit of the software interrupt event register (EXTI\_SWIE).

## 6.2.4 EXTI line mapping

To configure external interrupts/events on the GPIO line by AFIO\_CFG.EXTI\_ETRR[4:0], the AFIO clock must be enabled first. The general-purpose I/O ports and internal modules are connected as follows:

- EXTI line 0 is connected to PA0
- EXTI line 1 is connected to PA1
- EXTI line 2 is connected to PA2
- EXTI line 3 is connected to PA3
- EXTI line 4 is connected to PA4
- EXTI line 5 is connected to PA5
- EXTI line 6 is connected to PA6
- EXTI line 7 is connected to PA7
- EXTI line 8 is connected to PA8
- EXTI line 9 is connected to PA9
- EXTI line 10 is connected to PA10
- EXTI line 11 is connected to PA11
- EXTI line 12 is connected to PA12
- EXTI line 13 is connected to PA13
- EXTI line 14 is connected to PA14
- EXTI line 15 is connected to PA15
- EXTI line 16 is connected to PB0



- EXTI line 17 is connected to PB1
- EXTI line 18 is connected to PVD
- EXTI line 19 is connected to TIM6 wake up event

## **6.3 EXTI Registers**

EXTI base address: 0x40003400

## 6.3.1 EXTI register overview

#### Table 6-2 EXTI register overview

| Offset | Register    | 31 | 10 | 50 | 29 | ŝ        | 0, 10 | 17 | 26   | 25   | 24 | 23 | ; | 22 | 21 | 20 | 19       | 18       | 17       | 16       | 15       | 14       | 13       | 12       | Π        | 10       | 6       | ~       | ۲       | 9       | 5       | 4       | 3       | 2       | 1       | 0             |
|--------|-------------|----|----|----|----|----------|-------|----|------|------|----|----|---|----|----|----|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------------|
| 000h   | EXTI_IMASK  |    |    |    |    | <u> </u> |       | F  | Rese | rved |    |    |   |    |    |    | IMASK19  | IMASK18  | TMASK17  | IMASK16  | IMASK15  | IMASK14  | IMASK13  | IMASK12  | IMASK11  | IMASK10  | 6XSAMI  | IMASK8  | IMASK7  | IMASK6  | IMASK5  | IMASK4  | IMASK3  | IMASK2  | IMASKI  | <b>IMASK0</b> |
|        | Reset Value |    |    |    |    |          |       |    |      |      |    |    |   |    |    |    | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0             |
| 004h   | EXTI_EMASK  |    |    |    |    |          |       | F  | Rese | rved |    |    |   |    |    |    | EMASK19  | EMASK18  | EMASK17  | EMASK16  | EMASK15  | EMASK14  | EMASK13  | EMASK12  | EMASK11  | EMASK10  | EMASK9  | EMASK8  | EMASK7  | EMASK6  | EMASK5  | EMASK4  | EMASK3  | EMASK2  | EMASK1  | <b>EMASK0</b> |
|        | Reset Value |    |    |    |    |          |       |    |      |      |    |    |   |    |    |    | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0             |
| 008h   | EXTI_RT_CFG |    |    |    |    |          |       | F  | Rese | rved |    |    |   |    |    |    | RT_CFG19 | RT_CFG18 | RT_CFG17 | RT_CFG16 | RT_CFG15 | RT_CFG14 | RT_CFG13 | RT_CFG12 | RT_CFG11 | RT_CFG10 | RT_CFG9 | RT_CFG8 | RT_CFG7 | RT_CFG6 | RT_CFG5 | RT_CFG4 | RT_CFG3 | RT_CFG2 | RT_CFG1 | RT_CFG0       |
|        | Reset Value |    |    |    |    |          |       |    |      |      |    |    |   |    |    |    | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0             |
| 00Ch   | EXTI_FT_CFG |    |    |    |    |          |       | F  | Rese | rved |    |    |   |    |    |    | FT_CFG19 | FT_CFG18 | FT_CFG17 | FT_CFG16 | FT_CFG15 | FT_CFG14 | FT_CFG13 | FT_CFG12 | FT_CFG11 | FT_CFG10 | FT_CFG9 | FT_CFG8 | FT_CFG7 | FT_CFG6 | FT_CFG5 | FT_CFG4 | FT_CFG3 | FT_CFG2 | FT_CFG1 | FT_CFG0       |
|        | Reset Value |    |    |    |    |          |       |    |      |      |    |    |   |    |    |    | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0             |
| 010h   | EXTI_SWIE   |    |    |    |    |          |       | F  | Rese | rved |    |    |   |    |    |    | SWIE19   | SWIE18   | SWIE17   | SWIE16   | SWIE15   | SWIE14   | SWIE13   | SWIE12   | SWIE11   | SWIE10   | 8WIE9   | SWIE8   | SWIE7   | SWIE6   | SWIE5   | SWIE4   | SWIE3   | SWIE2   | SWIE1   | SWIE0         |
|        | Reset Value |    |    |    |    |          |       |    |      |      |    |    |   |    |    |    | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0             |
| 014h   | EXTI_PEND   |    |    |    |    |          |       | F  | Rese | rved |    |    |   |    |    |    | PEND19   | PEND18   | PEND17   | PEND16   | PEND15   | PEND14   | PEND13   | PEND12   | PEND11   | PEND10   | PEND9   | PEND8   | PEND7   | PEND6   | PEND5   | PEND4   | PEND3   | PEND2   | PEND1   | PEND0         |
|        | Reset Value |    |    |    |    |          |       |    |      |      |    |    |   |    |    |    | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0             |

# 6.3.2 Interrupt mask register(EXTI\_IMASK)

Address offset : 0x00

### Reset value : 0x0000000

| 31      |         |         |         |         |         |        |        |        |        |        | 20     | 19      | 18      | 17      | 16      |
|---------|---------|---------|---------|---------|---------|--------|--------|--------|--------|--------|--------|---------|---------|---------|---------|
|         |         | 1       | 1       |         | Rese    | rved   | 1      | 1      |        |        | 1      | IMASK19 | IMASK18 | IMASK17 | IMASK16 |
| 15      | 14      | 13      | 12      | 11      | 10      | 9      | 8      | 7      | 6      | 5      | 4      | rw<br>3 | rw<br>2 | rw<br>1 | rw<br>0 |
| IMASK15 | IMASK14 | IMASK13 | IMASK12 | IMASK11 | IMASK10 | IMASK9 | IMASK8 | IMASK7 | IMASK6 | IMASK5 | IMASK4 | IMASK3  | IMASK2  | IMASK1  | IMASK0  |
| rw      | rw      | rw      | rw      | rw      | rw      | rw     | rw     | rw     | rw     | rw     | rw     | rw      | rw      | rw      | rw      |

| Bit field | name     | describe                                      |
|-----------|----------|-----------------------------------------------|
| 31:20     | Reserved | Reserved, the reset value must be maintained. |



| 19:0 | IMASKx | Interrupt mask on line x. (x is 0,1,219)   |
|------|--------|--------------------------------------------|
|      |        | 0: Mask the interrupt request from line x; |
|      |        | 1: Open the interrupt request from line x  |

# 6.3.3 Event mask register(EXTI\_EMASK)

Address offset : 0x04

Reset value : 0x00000000

| 31      |         |         |         |         |         |        |        |        |        |        | 20     | 19      | 18      | 17      | 16      |
|---------|---------|---------|---------|---------|---------|--------|--------|--------|--------|--------|--------|---------|---------|---------|---------|
|         |         | 1       |         |         | Rese    | erved  |        |        |        | 1      |        | EMASK19 | EMASK18 | EMASK17 | EMASK16 |
| 15      | 14      | 13      | 12      | 11      | 10      | 9      | 8      | 7      | 6      | 5      | 4      | rw<br>3 | rw<br>2 | rw<br>1 | rw<br>0 |
| EMASK15 | EMASK14 | EMASK13 | EMASK12 | EMASK11 | EMASK10 | EMASK9 | EMASK8 | EMASK7 | EMASK6 | EMASK5 | EMASK4 | EMASK3  | EMASK2  | EMASK1  | EMASK0  |
| rw      | rw      | rw      | rw      | rw      | rw      | rw     | rw     | rw     | rw     | rw     | rw     | rw      | rw      | rw      | rw      |

| Bit field | name     | describe                                      |
|-----------|----------|-----------------------------------------------|
| 31:20     | Reserved | Reserved, the reset value must be maintained. |
| 19:0      | EMASKx   | Event masking on line x. (x is 0,1,219)       |
|           |          | 0: Masking the event request from line x;     |
|           |          | 1: Open the event request from line x         |

# 6.3.4 **Rising edge trigger selection register(EXTI\_RT\_CFG)**

Address offset : 0x08

Reset value : 0x00000000

| 31           |              |              |              |              |              |             |             |             |             |             | 20          | 19           | 18           | 17           | 16           |
|--------------|--------------|--------------|--------------|--------------|--------------|-------------|-------------|-------------|-------------|-------------|-------------|--------------|--------------|--------------|--------------|
|              |              |              |              |              | Rese         | rved        | 1           |             |             | 1           |             | RT<br>_CFG19 | RT<br>_CFG18 | RT<br>_CFG17 | RT<br>_CFG16 |
| 15           | 14           | 13           | 12           | 11           | 10           | 9           | 8           | 7           | 6           | 5           | 4           | rw<br>3      | rw<br>2      | rw<br>1      | rw<br>0      |
| RT<br>_CFG15 | RT<br>_CFG14 | RT<br>_CFG13 | RT<br>_CFG12 | RT<br>_CFG11 | RT<br>_CFG10 | RT<br>_CFG9 | RT<br>_CFG8 | RT<br>_CFG7 | RT<br>_CFG6 | RT<br>_CFG5 | RT<br>_CFG4 | RT<br>_CFG3  | RT<br>_CFG2  | RT<br>_CFG1  | RT<br>_CFG0  |
| rw           | rw           | rw           | rw           | rw           | rw           | rw          | rw          | rw          | rw          | rw          | rw          | rw           | rw           | rw           | rw           |

| Bit field | name     | ame describe                                                                          |  |  |  |  |  |  |  |  |  |  |
|-----------|----------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| 31:20     | Reserved | Reserved, the reset value must be maintained.                                         |  |  |  |  |  |  |  |  |  |  |
| 19:0      | RT_CFGx  | The rising edge on line x triggers the configuration bit. $(x \text{ is } 0, 1, 219)$ |  |  |  |  |  |  |  |  |  |  |
|           |          | 0: Disables rising edge trigger (interrupts and events) on input line x.              |  |  |  |  |  |  |  |  |  |  |
|           |          | 1: Enable rising edge trigger (interrupts and events) on input line x.                |  |  |  |  |  |  |  |  |  |  |

# 6.3.5 Falling edge trigger selection register(EXTI\_FT\_CFG)

Address offset : 0x0C



#### Reset value : 0x0000000

| 31           |              |              |              |              |              |             |             |             |             |             | 20          | 19           | 18           | 17           | 16           |
|--------------|--------------|--------------|--------------|--------------|--------------|-------------|-------------|-------------|-------------|-------------|-------------|--------------|--------------|--------------|--------------|
|              |              |              | 1            |              | Rese         | rved        |             |             |             | 1           | 1           | FT<br>_CFG19 | FT<br>_CFG18 | FT<br>_CFG17 | FT<br>_CFG16 |
| 15           | 14           | 13           | 12           | 11           | 10           | 9           | 8           | 7           | 6           | 5           | 4           | rw<br>3      | rw<br>2      | rw<br>1      | rw<br>0      |
| FT<br>_CFG15 | FT<br>_CFG14 | FT<br>_CFG13 | FT<br>_CFG12 | FT<br>_CFG11 | FT<br>_CFG10 | FT<br>_CFG9 | FT<br>_CFG8 | FT<br>_CFG7 | FT<br>_CFG6 | FT<br>_CFG5 | FT<br>_CFG4 | FT<br>_CFG3  | FT<br>_CFG2  | FT<br>_CFG1  | FT<br>_CFG0  |
| rw           | rw           | rw           | rw           | rw           | rw           | rw          | rw          | rw          | rw          | rw          | rw          | rw           | rw           | rw           | rw           |

| Bit field | name     | describe                                                                     |
|-----------|----------|------------------------------------------------------------------------------|
| 31:20     | Reserved | Reserved, the reset value must be maintained.                                |
| 19:0      | FT_CFGx  | The falling edge on line x triggers the configuration bit. (x is $0,1,219$ ) |
|           |          | 0: Disables falling edge trigger (interrupts and events) on input line x.    |
|           |          | 1: Enable falling edge trigger (interrupts and events) on input line x.      |

## 6.3.6 Software interrupt enable register(EXTI\_SWIE)

Address offset : 0x10

Reset value : 0x0000000

| 31     |        |        |        |        |        |       |       |       |       |       | 20    | 19      | 18      | 17      | 16      |
|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|---------|---------|---------|---------|
|        | 1      | 1      | 1      | 1      | Rese   | prved | 1     | 1     | 1     | 1     | 1     | SWIE19  | SWIE18  | SWIE17  | SWIE16  |
| 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8     | 7     | 6     | 5     | 4     | rw<br>3 | rw<br>2 | rw<br>1 | rw<br>0 |
| SWIE15 | SWIE14 | SWIE13 | SWIE12 | SWIE11 | SWIE10 | SWIE9 | SWIE8 | SWIE7 | SWIE6 | SWIE5 | SWIE4 | SWIE3   | SWIE2   | SWIE1   | SWIE0   |
| rw     | rw     | rw     | rw     | rw     | rw     | rw    | rw    | rw    | rw    | rw    | rw    | rw      | rw      | rw      | rw      |

| Bit field | name     | describe                                                                              |
|-----------|----------|---------------------------------------------------------------------------------------|
| 31:20     | Reserved | Reserved, the reset value must be maintained.                                         |
| 19:0      | SWIEx    | Software interrupt on line x. $(x \text{ is } 0, 1, 219)$                             |
|           |          | When the bit is' 0 ', writing '1' sets the corresponding pending bit in EXTI_PEND. If |
|           |          | this interrupt is allowed in EXTI_IMASK and EXTI_EMASK, an interrupt will be          |
|           |          | generated.                                                                            |
|           |          | Note: This bit can be cleared to '0' by writing '1' to clear the corresponding bit of |
|           |          | EXTI_PEND.                                                                            |

# 6.3.7 Interrupt request pending register(EXTI\_PEND)

Address offset : 0x14

Reset value : 0x0000000



| 31     |        |        |        |        |        |       |       |       |       |       | 20    | 19         | 18         | 17         | 16         |
|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|------------|------------|------------|------------|
|        | 1      | 1      | 1      |        | Rese   | erved | 1     | 1     |       | 1     | 1     | PEND19     | PEND18     | PEND17     | PEND16     |
| 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8     | 7     | 6     | 5     | 4     | rc_w1<br>3 | rc_w1<br>2 | rc_w1<br>1 | rc_w1<br>0 |
| PEND15 | PEND14 | PEND13 | PEND12 | PEND11 | PEND10 | PEND9 | PEND8 | PEND7 | PEND6 | PEND5 | PEND4 | PEND3      | PEND2      | PEND1      | PEND0      |
| rc_w1  | rc_w1  | rc_w1  | rc_w1  | rc_w1  | rc_w1  | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1      | rc_w1      | rc_w1      | rc_w1      |

| name     | describe                                                                                   |
|----------|--------------------------------------------------------------------------------------------|
| Reserved | Reserved, the reset value must be maintained.                                              |
| PENDx    | Hang bit on line x. $(x \text{ is } 0, 1, 219)$                                            |
|          | 0: No pending request occurred.                                                            |
|          | 1: A pending trigger request has occurred.                                                 |
|          | This bit is set to '1' when a selected edge trigger event occurs on the external interrupt |
|          | line. It can be cleared by writing '1' to the bit.                                         |
|          | Reserved                                                                                   |



# 7 CRC calculation unit

# 7.1 CRC introduction

This module integrates the functions of CRC16, and the cyclic redundancy check (CRC) calculation unit obtains any CRC calculation result according to a fixed generator polynomial. In other applications, CRC technology is mainly used to verify the correctness and integrity of data transmission or data storage. CRC calculation unit can calculate the identifier of the software when the program is running, then compare it with the reference identifier generated during connection, and then store it in the specified memory space.

# 7.2 CRC main features

- CRC16( $X^{16}+X^{15}+X^2+1$ )
- There are 8 bits of data to be checked and 16 bits of output check code.
- CRC calculation time: 1 AHB clock cycle (HCLK)
- The verification initial value can be configured, and the size end of the data to be verified can be configured.
- Support 8bit LRC check value generation

The following figure is the block diagram of CRC unit.





# 7.3 CRC function description

CRC\_CRC16CTRL.ENDHL controls little endian or big endian.

To clear the result of the last CRC operation, set CRC\_CRC16CTRL.CLR to 1 or CRC\_CRC16D to 0.

The initial value of CRC calculation can be configured by writing the CRC\_CRC16D register. By default, the initial value is the result of the last calculation.



LRC calculation is the same as CRC calculation. Both are carried out at the same time. CRC or LRC can be read out depending on needs. If the initial value needs to be set, the LRC register should be configured first.

# 7.4 CRC software calculation method

In practical applications, if you need to calculate CRC16 through software to match the hardware calculation results, you need to correctly configure the following:

- WIDTH: 16
- POLY: 0x8005
- INIT: 0x0000
- XOROUT: 0x0000
- REFIN: No
- REFOUT: No

# 7.5 CRC registers

## 7.5.1 CRC register overview

The following table lists the registers and reset values of CRC.

Table 7-1 CRC register overview

| Offset | Register    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23   | 22 | 21 | 20   | 19   | 18 | 17     | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 6 | 8    | 7     | 9   | 5  | 4    | 3     | 2   | 1     | 0        |
|--------|-------------|----|----|----|----|----|----|----|------|------|----|----|------|------|----|--------|----|----|----|----|----|----|----|---|------|-------|-----|----|------|-------|-----|-------|----------|
| 00Ch   | CRC16CTRL   |    |    |    |    |    |    |    |      |      |    |    |      |      | R  | leserv | ed |    |    |    |    |    |    |   |      |       |     |    |      |       | CLR | ENDHL | Reserved |
|        | Reset Value |    |    |    |    |    |    |    |      |      |    |    |      |      |    |        |    |    |    |    |    |    |    |   |      |       |     |    |      |       | 0   | 0     | R        |
| 0101   | CRC16DAT    |    |    |    |    |    |    |    |      |      |    |    | P    |      |    |        |    |    |    |    |    |    |    |   |      |       |     | CR | C16E | DAT[7 | :0] |       |          |
| 010h   | Reset Value |    |    |    |    |    |    |    |      |      |    |    | Rese | rved |    |        |    |    |    |    |    |    |    |   |      | 0     | 0   | 0  | 0    | 0     | 0   | 0     | 0        |
| 01.41  | CRC16D      |    |    |    |    |    |    |    | D    |      |    |    |      |      |    |        |    |    |    |    |    |    |    | С | RC16 | D[15: | :0] |    |      |       |     |       |          |
| 014h   | Reset Value |    |    |    |    |    |    |    | Rese | rved |    |    |      |      |    |        |    | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0    | 0     | 0   | 0  | 0    | 0     | 0   | 0     | 0        |
| 0191   | LRC         |    |    |    |    |    |    |    |      |      |    |    | D    |      |    |        |    |    |    |    |    |    |    |   |      |       |     | L  | RCD  | AT[7: | 0]  |       |          |
| 018h   | Reset Value |    |    |    |    |    |    |    |      |      |    |    | Rese | rved |    |        |    |    |    |    |    |    |    |   |      | 0     | 0   | 0  | 0    | 0     | 0   | 0     | 0        |

# 7.5.2 CRC16 control register (CRC\_CRC16CTRL)

Address offset: 0x0C

Reset value: 0x0000 0000



Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China





| Bit field | Name     | Description                                                                                    |
|-----------|----------|------------------------------------------------------------------------------------------------|
| 31:3      | Reserved | Reserved, the reset value must be maintained                                                   |
| 2         | CLR      | Clear CRC16 results.                                                                           |
|           |          | 0: Not clear.                                                                                  |
|           |          | 1: Clear to default value 0x0000. Set this bit to 1 will only maintain 1 clock cycle, hardware |
|           |          | will clear automatically. (Software read always 0).                                            |
| 1         | ENDHL    | Data to be verified start to calculate from MSB or LSB.                                        |
|           |          | 0: From MSB to LSB                                                                             |
|           |          | 1: From LSB to MSB                                                                             |
|           |          | This bit is only for data to be verified.                                                      |
| 0         | Reserved | Reserved, the reset value must be maintained                                                   |

Note: 8-bits, 16-bits and 32-bits operations are supported.

# 7.5.3 CRC16 input data register (CRC\_CRC16DAT)

### Address offset: 0x10

Reset value: 0x0000 0000



| Bit field | Name          | Description                                  |
|-----------|---------------|----------------------------------------------|
| 31:8      | Reserved      | Reserved, the reset value must be maintained |
| 7:0       | CRC16DAT[7:0] | Data to be verified.                         |

Note: 8-bits, 16-bits and 32-bits operations are supported.

## 7.5.4 CRC cyclic redundancy check code register (CRC\_CRC16D)

Address offset: 0x14

Reset value: 0x0000 0000



 Bit field
 Name
 Description

 31:16
 Reserved
 Reserved, the reset value must be maintained



| Bit field | Name         | Description                                                                           |
|-----------|--------------|---------------------------------------------------------------------------------------|
| 15:0      | CRC16D[15:0] | 16-bit value of cyclic redundancy result data.                                        |
|           |              | Every time the software writes the CRC16DAT register, the 16-bit calculated data from |
|           |              | CRC16 is updated in this register.                                                    |

Note: 8-bits, 16-bits and 32-bits operations are supported (8-bit operations must be performed twice in a row to ensure that 16-bit initial values are configured properly)

# 7.5.5 LRC result register (CRC\_LRC)

Address offset: 0x18

Reset value: 0x0000 0000

| 31 |   | <br>   |      |                   | <br> |       |   |   |       |         |   | <br>16 |
|----|---|--------|------|-------------------|------|-------|---|---|-------|---------|---|--------|
|    |   |        |      |                   | Rese | erved | • | • |       | I       |   |        |
|    | I | <br>LI |      | LI                | I    | I     | I | I | I     | I       | I |        |
| 15 |   |        |      |                   | 8    | 7     |   |   |       |         |   | 0      |
|    |   | Rese   | rved |                   |      |       |   |   | LRCD. | AT[7:0] |   |        |
|    |   | <br>   |      | · · · · · · · · · |      |       |   |   | r     | w       |   | <br>   |

| Bit field | Name        | Description                                                                         |
|-----------|-------------|-------------------------------------------------------------------------------------|
| 31:8      | Reserved    | Reserved, the reset value must be maintained                                        |
| 7:0       | LRCDAT[7:0] | LRC check value register.                                                           |
|           |             | Software need to write initial value before use. And then each time data written to |
|           |             | CRC_CRC16DAT is "XOR" with the value of the CRC_LCR register. The result will be    |
|           |             | stored in CRC_LCR. Software read the result. It should be cleared before next use.  |



# 8 Advanced-control timers (TIM1)

# 8.1 TIM1 introduction

The advanced control timers (TIM1) is mainly used in the following occasions: counting the input signal, measuring the pulse width of the input signal and generating the output waveform, etc.

Advanced timers have complementary output function with dead-time insertion and break function. Suitable for motor control.

# 8.2 Main features of TIM1

- 16-bit auto-reload counters. (It can realize up-counting, down-counting, up/down counting)
- 16-bit programmable prescaler. (The frequency division factor can be configured with any value between 1 and 65536)
- Programmable Repetition Counter
- TIM1 up to 5 channels.
- 4 capture/compare channels, the working modes are PWM output, ouput compare, one-pulse mode output, input capture.
- The events that generate the interrupt are as follows:
  - Update event
  - Trigger event
  - Input capture
  - Output compare
  - Break input
- Complementary outputs with adjustable dead-time
  - For TIM1, channel 1,2,3 support this feature
- Timer can be controlled by external signal
- Timers are linked internally for timer synchronization or chaining
- TIM1\_CC5 for COMP blanking



#### Figure 8-1 Block diagram of TIM1



The capture channel 1 input can come from IOM or comparator output

# 8.3 TIM1 function description

# 8.3.1 **Time-base unit**

The advanced-control's time-base unit mainly includes: prescaler, counter, auto-reload and repetition counter. When the time base unit is working, the software can read and write the corresponding registers (TIMx\_PSC, TIMx\_CNT, TIMx\_AR and TIMx\_REPCNT) at any time.

Depending on the setting of the auto-reload preload enable bit (TIMx\_CTRL1.ARPEN), the value of the preload register is transferred to the shadow register immediately or at each update event UEV. An update event is generated when the counter reaches the overflow/underflow condition and it can be generated by software when



TIMx\_CTRL1.UPDIS=0. The counter CK\_CNT is valid only when the TIMx\_CTRL1.CNTEN bit is set. The counter starts counting one clock cycle after the TIMx\_CTRL1.CNTEN bit is set.

### 8.3.1.1 **Prescaler description**

The TIMx\_PSC register consists of a 16-bit counter that can be used to divide the counter clock frequency by any factor between 1 and 65536. It can be changed on the fly as it is buffered. The prescaler value is only taken into account at the next update event.



### Figure 8-2 Counter timing diagram with prescaler division change from 1 to 4

### 8.3.2 Counter mode

### 8.3.2.1 Up-counting mode

In up-counting mode, the counter will count from 0 to the value of the register TIMx\_AR, then it resets to 0. And a counter overflow event is generated.

If the TIMx\_CTRL1.UPRS bit (select update request) and the TIMx\_EVTGEN.UDGN bit are set, an update event (UEV) will generate. And TIMx\_STS.UDITF will not be set by hardware, therefore, no update interrupts are generated. This setting is used in scenarios where you want to clear the counter but do not want to generate an update interrupt.

Depending on the update request source is configured in the TIMx\_CTRL1.UPRS, When an update event occurs, all registers are updated and the TIMx\_STS.UDITF is set:

■ The repetition counter reloads the contents of the TIMx\_REPCNT



- Update auto-reload shadow registers with preload value(TIMx\_AR), when TIMx\_CTRL1.ARPEN = 1.
- The prescaler shadow register is reloaded with the preload value(TIMx\_PSC).

To avoid updating the shadow registers when new values are written to the preload registers, you can disable the update by setting TIMx\_CTRL1.UPDIS=1.

When an update event occurs, the counter will still be cleared and the prescaler counter will also be set to 0 (but the prescaler value will remain unchanged).

The figure below shows some examples of the counter behavior and the update flags for different division factors in the up-counting mode.



#### Figure 8-3 Timing diagram of up-counting. The internal clock divider factor = 2/N

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China





#### Figure 8-4 Timing diagram of the up-counting, update event when ARPEN=0/1

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



### 8.3.2.2 **Down-counting mode**

In down-counting mode, the counter will decrement from the value of the register TIMx\_AR to 0, then restart from the auto-reload value and generate a counter underflow event.

The process of configuring update events and updating registers in down-counting mode is the same as in up-counting mode, see 8.3.2.1.

The figure below shows some examples of the counter behavior and the update flags for different division factors in the down-counting mode.



Figure 8-5 Timing diagram of the down-counting, internal clock divided factor = 2/N

### 8.3.2.3 Center-aligned mode

In center-aligned mode, the counter increments from 0 to the value  $(TIMx_AR) - 1$ , a counter overflow event is generated. It then counts down from the auto-reload value  $(TIMx_AR)$  to 1 and generates a counter underflow event. Then the counter resets to 0 and starts counting up again.

In this mode, the TIMx\_CTRL1.DIR direction bits have no effect and the count direction is updated and specified by hardware. Center-aligned mode is valid when the TIMx\_CTRL1. CAMSEL bit is not equal to "00".

The update events can be generated each time the counter overflows and each time the counter underflows. Alternatively, an update event can also be generated by setting the TIMx\_EVTGEN. UDGN bit (either by software



or using a slave mode controller). In this case, the counter restarts from 0, as does the prescaler's counter.

Please note: if the update source is a counter overflow, auto-reload update before reloading the counter.

#### Figure 8-6 Timing diagram of the Center-aligned, internal clock divided factor =2/N

| Internal clock divided by 2 | CK_PSC<br>CNTEN                            |                                    |
|-----------------------------|--------------------------------------------|------------------------------------|
|                             | Timer clock = CK_CNT                       |                                    |
|                             | Counter register                           | 0003 0002 0001 0000 0001 0002 0003 |
|                             | Counter underflow                          | T                                  |
|                             | Update event (UEV)                         |                                    |
| Upd                         | ate interrupt flag(UDITF)                  |                                    |
| Internal clock<br>by N      | divided<br>ск_рsc _                        |                                    |
| Tin                         | ner clock = CK_CNT                         |                                    |
|                             | Counter register                           | 20 IF / 01 00                      |
|                             | Counter underflow                          |                                    |
|                             | Jpdate event (UEV)<br>nterrupt flag(UDITF) |                                    |
| Opdate in                   | (ODIT)                                     |                                    |





Figure 8-7 A center-aligned sequence diagram that includes counter overflows and underflows (ARPEN = 1)

# 8.3.3 Repetition counter

The basic unit of Section 8.3.1 describes the conditions for generating an update event (UEV). An update event (UEV) is actually only generated when the repeat counter reaches zero, which is valuable for generating PWM signals.

This means that data is transferred from the preload registers to the shadow registers every N+1 counter overflow or underflow, where N is the value in the TIMx\_REPCNT.



The repetition counter is decremented:

- In the up-counting mode, each time the counter reaches the maximum value, an overflow occurs.
- In down-counting mode, each time the counter decrements to the minimum value, an underflow occurs.
- In center-aligned mode, each time the counter overflows or underflows.

Its repetition rate is defined by the value of the TIMx\_REPCNT register.

Repetition counters feature automatic reloading. The update event (generated by setting TIMx\_EVTGEN.UDGN or hardware through slave mode controller) occurs immediately, regardless of the value of the repeat counter.



### Figure 8-8 Repeat count sequence diagram in down-counting mode









Software clear

Figure 8-10 Repeat count sequence diagram in center-aligned mode







# 8.3.4 Clock selection

- The internal clock of Advanced-control timers : CK\_INT
- Two kinds of external clock mode :
  - external input pin
  - external trigger input ETR
- Internal trigger input (ITRx): one timer is used as a prescaler for another timer.

### 8.3.4.1 Internal clock source (CK\_INT)

When the TIMx\_SMCTRL.SMSEL is equal to "000", the slave mode controller is disabled. The three control bits (TIMx\_CTRL1.CNTEN、TIMx\_CTRL1.DIR、TIMx\_EVTGEN.UDGN) can only be changed by software (except TIMx\_EVTGEN.UDGN, which remains cleared automatically ). It is provided that the TIMx\_CTRL1.CNTEN bit is written as' 1 ' by soft, the clock source of the prescaler is provided by the internal clock CK\_INT.

### Figure 8-11 Control circuit in normal mode, internal clock divided by 1





### 8.3.4.2 External clock source mode 1





This mode is selected by configuring TIMx\_SMCTRL.SMSEL=111. The counter can be configured to count on the rising or falling edge of the clock at the selected input.

For example, to configure up-counting mode to count on the rising edge of the clock at the TI2 input, the configuration steps are as follows:

- Configure TIMx\_CCMOD1.CC2SEL equal to '01', CC2 channel is configured as input, IC2 is mapped to TI2
- Configure TIMx\_CCEN.CC2P equal to '0', select clock rising edge polarity
- To select input filter bandwidth by configuring TIMx\_CCMOD1.IC2F[3:0] (if filter is not needed, keep IC2F bit at '0000')
- Configure TIMx\_SMCTRL.SMSEL equal to '111', select timer external clock mode 1
- Configure TIMx\_SMCTRL.TSEL equal to '110', select TI2 as the trigger input source
- Configure TIMx\_CTRL1.CNTEN equal to '1' to start the counter

Note: The capture prescaler is not used for triggering, so it does not need to be configured

When the rising edge of the timer clock occurs at TI2=1, the counter counts once and the TIMx\_STS .TITF flag is pulled high.

The delay between the rising edge of TI2 and the actual clock of the counter depends on the resynchronization circuit at the input of TI2.



#### Figure 8-13 Control circuit in external clock mode 1



### 8.3.4.3 External clock source mode 2

This mode is selected by TIMx\_SMCTRL.EXCEN equal to 1. The counter can count on every rising or falling edge of the external trigger input ETR.

The following figure is a schematic diagram of the external trigger input module in External clock source mode 2

Figure 8-14 External trigger input block diagram



For example, use the following configuration steps to make the up counter count every 2 rising edges on ETR.

- Since no filter is needed in this case, make TIMx\_SMCTRL .EXTF[3:0] equal to '0000'
- Configure the prescaler by making TIMx\_SMCTRL.EXTPS[1:0] equal to '01'
- Select the polarity on ETR pin by setting TIMx\_SMCTRL.EXTP equal to '0', The rising edge of ETR is valid

122 / 319



- External clock mode 2 is selected by setting TIMx\_SMCTRL .EXCEN equal to '1'
- Turn on the counter by setting TIMx\_CTRL1. CNTEN equal to '1'

The counter counts every 2 rising edges of ETR. The delay between the rising edge of ETR and the actual clock to the counter is due to a resynchronization circuit on the ETRP signal.



#### Figure 8-15 Control circuit in external clock mode 2

# 8.3.5 Capture/compare channels

Capture/compare channels include capture/compare registers and shadow registers. The input section consists of digital filters, multiplexers and prescalers. The output section includes comparators and output controls.

The input signal TIx is sampled and filtered to generate the signal TIxF. A signal (TIxF\_rising or TIxF\_falling) is then generated by the edge detector of the polarity select function, the polarity of which is selected by the TIMx\_CCEN.CCxP bits. This signal can be used as a trigger input for the slave mode controller. At the same time, the signal ICx is sent to the capture register after frequency division. The following figure shows a block diagram of a capture/compare channel.





#### Figure 8-16 Capture/compare channel (example: channel 1 input stage)

The output part generates an intermediate waveform OCxRef (active high) as reference. The polarity acts at the end of the chain.





#### Figure 8-17 Capture/compare channel 1 main circuit



#### Figure 8-18 Output part of channelx (x= 1,2,3, take channel 1 as example)



Figure 8-19 Output part of channelx (x= 4)



Reads and writes always access preloaded registers when capturing/comparing. The two specific working processes are as follows:

In capture mode, the capture is actually done in the shadow register, and then the value in the shadow register is copied into the preload register.

In compare mode, as opposed to capture mode, the value of the preload register is copied into the shadow register, which is compared with the counter.

# 8.3.6 **Input capture mode**

In capture mode, the TIMx\_CCDATx registers are used to latch the counter value after the ICx signal detects.

There is a capture interrupt flag TIMx\_STS.CCxITF, which can issue an interrupt if the corresponding interrupt enable is pulled high.

The TIMx\_STS. CCxITF bit is set by hardware when a capture event occurs and is cleared by software or by reading the TIMx\_CCDATx register.



The overcapture flag TIMx\_STS.CCxOCF is set equal to 1 when the counter value is captured in the TIMx\_CCDATx register and TIMx\_STS.CC1ITF is already pulled high. Unlike the former, TIMx\_STS.CCxOCF is cleared by writing 0 to it.

To achieve a rising edge of the TI1 input to capture the counter value into the TIMx\_CCDAT1 register, the configuration flow is as follows:

To select a valid input:

Configure TIMx\_CCMOD1.CC1SEL to '01'. At this time, the input is the CC1 channel, and IC1 is mapped to TI1.

■ Program the desired input filter duration:

Define the sampling frequency of the TI1 input and the length of the digital filter by configuring the TIMx\_CCMODx.ICxF bits. Example: If the input signal jitters up to 5 internal clock cycles, we must choose a filter duration longer than these 5 clock cycles. When 8 consecutive samples (sampled at  $f_{DTS}$  frequency) with the new level are detected, we can validate the transition on TI1. Then configure TIMx\_CCMOD1. IC1F to '0011'.

- By configuring TIMx\_CCEN .CC1P=0, select the rising edge as the valid transition polarity on the TI1 channel.
- Configure the input prescaler. In this example, configure TIMx\_CCMOD1.IC1PSC= '00' to disable the prescaler because we want to capture every valid transition.
- Enable capture by configuring TIMx\_CCEN. CC1EN = '1'.

If you want enable related interrupt request, you can configureTIMx\_DINTEN.CC1IEN bit=1

# 8.3.7 **PWM input mode**

There are some differences between PWM input mode and normal input capture mode, including:

- Two ICx signals are mapped to the same TIx input.
- The two ICx signals are active on edges of opposite polarity.
- Select one of two TIxFP signals as trigger input.
- The slave mode controller is configured in reset mode.

For example, the following configuration flow can be used to know the period and duty cycle of the PWM signal on TI1 (It depends on the frequency of CK\_INT and the value of the prescaler).

- Configure TIMx\_CCMOD1.CC1SEL equal to '01' to select TI1 as valid input for TIMx\_CCDAT1.
- Configure TIMx\_CCEN.CC1P equal to '0' to select the active polarity of filtered timer input 1(TI1FP1), valid on the rising edge.
- Configure TIMx\_CCMOD1.CC2SEL equal to '10' select TI1 as valid input for TIMx\_CCDAT2.
- Configure TIMx\_CCEN.CC2P equal to 1 to select the valid polarity of filtered timer input 2(TI1FP2), valid on the falling edge.
- Configure TIMx\_SMCTRL.TSEL=101 to select Filtered timer input 1 (TI1FP1) as valid trigger input.

127 / 319



- Configure TIMx\_SMCTRL.SMSEL=100 to configure the slave mode controller to reset mode.
- Configure TIMx\_CCEN. CC1EN=1 and TIMx\_CCEN.CC2EN=1 to enable capture.



#### Figure 8-20 PWM input mode timing

Because of only filter timer input 1 (TI1FP1) and filter timer input 2 (TI2FP2) are connected to the slave mode controller, the PWM input mode can only be used with the TIMx\_CH1/TIMx\_CH2 signals.

## 8.3.8 Forced output mode

Software can force output compare signals to active or inactive level directly, in output mode (TIMx\_CCMODx.CCxSEL=00).

User can set TIMx\_CCMODx. OCxMD=101 to force the output compare signal to active level. And the OCxREF will be forced high, OCx get opposite value to CCxP polarity bit. On the other hand, user can set TIMx\_CCMODx. OCxMD=100 to force the output compare signal to inactive level.

The values of the TIMx\_CCDATx shadow register and the counter still comparing with each other in this mode.

The comparison between the output compare register TIMx\_CCDATx and the counter TIMx\_CNT has no effect on OCxREF. And the flag still can be set. Therefore, the interrupt still can be sent.

## 8.3.9 **Output compare mode**

User can use this mode to control the output waveform, or to indicate that a period of time has elapsed.

When the capture/compare register and the counter have the same value, the output compare function's operations are as follow:



- TIMx\_CCMODx.OCxMD is for output compare mode, and TIMx\_CCEN.CCxP is for output polarity. When the compare matches, if set TIMx\_CCMODx.OCxMD=000, the output pin will keep its level; if set TIMx\_CCMODx.OCxMD=001, the output pin will be set active; if set TIMx\_CCMODx.OCxMD=010, the output pin will be set inactive; if set TIMx\_CCMODx.OCxMD=011, the output pin will be set to toggle.
- Set TIMx\_STS.CCxITF.
- If user set TIMx\_DINTEN.CCxIEN, a corresponding interrupt will be generated.

User can set TIMx\_CCMODx.OCxPEN to choose capture/compare shawdow register using capture/compare preload registers(TIMx\_CCDATx) or not.

The time resolution is one count of the counter.

In one-pulse mode, the output compare mode can also be used to output a single pulse.

Here are the configuration steps for output compare mode:

- First of all, user should select the counter clock.
- Secondly, set TIMx\_AR and TIMx\_CCDATx with desired data.
- If user need to generate an interrupt, set TIMx\_DINTEN.CCxIEN.
- Then select the output mode by set TIMx\_CCEN.CCxP, TIMx\_CCMODx.OCxMD, TIMx\_CCEN.CCxEN, etc.
- At last, set TIMx\_CTRL1.CNTEN to enable the counter.

User can update the output waveform by setting TIMx\_CCDATx at any time, as long as the preload register is not enabled. Otherwise the TIMx\_CCDATx shadow register will be updated at the next update event.

Here is an example.







# 8.3.10 **PWM mode**

User can use PWM mode to generate a signal whose duty cycle is determined by the value of the TIMx\_CCDATx register and whose frequency is determined by the value of the TIMx\_AR register. And depends on the value of TIMx\_CTRL1.CAMSEL, the TIM can generate PWM signal in edge-aligned mode or center-aligned mode.

User can set PWM mode 1 or PWM mode 2 by setting TIMx\_CCMODx. OCxMD=110 or setting TIMx\_CCMODx. OCxMD=111. To enable preload register, user must set corresponding TIMx\_CCMODx.OCxPEN. And then set TIMx\_CTRL1.ARPEN to auto-reload preload register eventually.

User can set polarity of OCx by setting TIMx\_CCEN.CCxP. On the other hand, to enable the output of OCx, user need to set the combination of the value of CCxEN, CCxNEN, MOEN, OSSI, and OSSR in TIMx\_CCEN and TIMx\_BKDT.

The values of TIMx\_CNT and TIMx\_CCDATx are always compared with each other when the TIM is under PWM mode.

Only if an update event occurs, the preload register will transfer to the shadow register. Therefore user must reset all the registers by setting TIMx\_EVTGEN.UDGN before the counter starts counting..

### 8.3.10.1 **PWM center-aligned mode**

If user set TIMx\_CTRL1.CAMSEL equal 01, 10 or 11, the PWM center-aligned mode will be active. The setting of the compare flag depends on the value of TIMx\_CTRL1.CAMSEL. There are three kinds of situation that the compare flag is set, only when the counter counts up, only when the counter counts down, or when the counter counts up and counts down. User should not modified TIMx\_CTRL1.DIR by software, it is updated by hardware.



Examples of center-aligned PWM waveforms is as follow, and the setting of the waveform are: TIMx\_AR=8, PWM mode 1, the compare flag is set when the counter counts down corresponding to TIMx\_CTRL1. CAMSEL=01.



Figure 8-22 Center-aligned PWM waveform (AR=8)

Notes that user should know when using center-aligned mode are as follow:

- It depends on the value of TIMx\_CTRL1.DIR that the counter counts up or down. Cautions that the DIR and CAMSEL bits should not be changed at the same time.
- User should not write the counter while running in center-aligned mode, otherwise it will cause unexpected results. Here are some example:
  - If the value written into the counter is 0 or is the value of TIMx\_AR, the direction will be updated but the update event will not be generated.
  - If the value written into the counter is greater than the value of auto-reload, the direction will not be updated.
- To be on the safe side, user is suggested setting TIMx\_EVTGEN.UDGN to generate an update by software before starting the counter, and not writing the counter while it is running.



### 8.3.10.2 PWM edge-aligned mode

There are two kinds of configuration in edge-aligned mode, up-counting and down-counting.

### • Up-counting

User can set TIMx\_CTRL1.DIR=0 to make counter counts up.

Here is an example for PWM mode1.

When TIMx\_CNT < TIMx\_CCDATx, the reference PWM signal OCxREF is high. Otherwise it will be low. If the compare value in TIMx\_CCDATx is greater than the auto-reload value, the OCxREF will remains 1. Conversely, if the compare value is 0, the OCxREF will remains 0.

When TIMx\_AR=8, the PWM waveforms are as follow.



Figure 8-23 Edge-aligned PWM waveform (APR=8)

### • Down-counting

User can set TIMx\_CTRL1.DIR=1 to make counter counts down.

Here is an example for PWM mode1.

When  $TIMx_CNT > TIMx_CCDATx$ , the reference PWM signal OCxREF is low. Otherwise it will be high. If the compare value in  $TIMx_CCDATx$  is greater than the auto-reload value, the OCxREF will remains 1.

Note: If the nth PWM cycle CCDATx shadow register >= AR value, the shadow register value of CCDATx in the (n+1)th PWM cycle is 0. At the moment when the counter is 0 in the (n+1)th PWM cycle, although the value of the

132 / 319



counter = CCDATx shadow register = 0 and OCxREF = '0', no compare event will be generated.

# 8.3.11 One-pulse mode

In the one-pulse mode (ONEPM), a trigger signal is received, and a pulse  $t_{PULSE}$  with a controllable pulse width is generated after a controllable delay  $t_{DELAY}$ . The output mode needs to be configured as output compare mode or PWM mode. After selecting one-pulse mode, the counter will stop counting after the update event UEV is generated.





The following is an example of a one-pulse mode:

A rising edge trigger is detected from the TI2 input, and a pulse with a width of  $t_{PULSE}$  is generated on OC1 after a delay of  $t_{DELAY}$ .

1. Counter configuration: count up, counter  $TIMx_CNT < TIMx_CCDAT1 \le TIMx_AR$ ;

2. TI2FP2 is mapped to TI2, TIMx\_CCMOD1.CC2SEL= '01'; TI2FP2 is configured for rising edge detection, TIMx\_CCEN.CC2P= '0';

3. TI2FP2 acts as the trigger (TRGI) of the slave mode controller and starts the counter, TIMx\_SMCTRL.TSEL= '110', TIMx\_SMCTRL.SMSEL= '110' (trigger mode);

4. TIMx\_CCDAT1 writes the count value to be delayed (t<sub>DELAY</sub>), TIMx\_AR - TIMx\_CCDAT1 is the count value of the pulse width t<sub>PULSE</sub>;

5. Configure TIMx\_CTRL1.ONEPM=1 to enable single pulse mode, configure TIMx\_CCMOD1.OC1MD = '111'to

133 / 319



select PWM2 mode;

6. Wait for an external trigger event on TI2, and a one pulse waveform will be output on OC1;

### 8.3.11.1 Special case: OCx fast enable:

In one-pulse mode, an edge is detected through the TIx input, and triggers the start of the counter to count to the comparison value and then output a pulse. These operations limit the minimum delay  $t_{DELAY}$  that can be achieved.

You can set TIMx\_CCMODx.OCxFEN=1 to turn on OCx fast enable, after triggering the rising edge, the OCxREF signal will be forced to be converted to the same level as the comparison match occurs immediately, regardless of the comparison result. OCxFEN fast enable only takes effect when the channel mode is configured for PWM1 and PWM2 modes.

## 8.3.12 Clearing the OCxREF signal on an external event

If user set TIMx\_CCMODx.OCxCEN=1, high level of ETRF input can be used to driven the OCxREF signal to low, and the OCxREF signal will remains low, until the next UEV happens. Only output compare and PWM modes can use this function. This cannot be used when it is in forced mode.

Here is an example for it. To control the current, user can connect the ETR signal to the output of a comparator, and the operation for ETR should be as follow:

- Set TIMx\_SMCTRL.EXTPS=00 to disable the external trigger prescaler.
- Set TIMx\_SMCTRL.EXCEN=0 to disable the external clock mode 2.
- Set TIMx\_SMCTRL.EXTP and TIMx\_SMCTRL.EXTF to configure the external trigger polarity and external trigger filter according to the need.

Here is an example for the case that when ETRF input becomes high, the behavior of OCxREF signal for different value of OCxCEN. Timer is set to be in PWM mode in this case.



### Figure 8-25 Clearing the OCxREF of TIMx



# 8.3.13 Complementary outputs with dead-time insertion

Advanced-control timer can output two complementary signals, and manage the switching-off and switching-on of outputs. This is called dead-time. User should adjust dead-time depending on the devices connected to the outputs and their characteristics.

User can select the polarity of outputs by setting TIMx\_CCEN.CCxP and TIMx\_CCEN.CCxNP. And this selection is independently for each output.

User can control the complementary signals OCx and OCxN by setting the combination of several control bits, which are TIMx\_CCEN.CCxEN, TIMx\_CCEN.CCxNEN, TIMx\_BKDT.MOEN, TIMx\_CTRL2.OIx, TIMx\_CTRL2.OIxN, TIMx\_BKDT.OSSI, and TIMx\_BKDT.OSSR. When switching to the IDLE state, the dead-time will be activated.

If user set TIMx\_CCEN.CCxEN and TIMx\_CCEN.CCxNEN at the same time, a dead-time will be insert. If there is a break circuit, the TIMx\_BKDT.MOEN should be set too. There are 10-bit dead-time generators for each channel.

Reference waveform OCxREF can generates 2 outputs OCx and OCxN. And if OCx and OCxN are active high, the OCx ouput signal is the same as the reference signal and the OCxN output signal is the opposite of the reference signal. However, OCx output signal will be delayed relative to the reference rising edge and the OCxN output signal will be delayed relative to the reference falling edge. If the delay is greater than the width of the active OCx or OCxN output, the corresponding pulse will not generated.

The relationships between the output signals of the dead-time generator and the reference signal OCxREF are as follow.

Assume that TIMx\_CCEN.CCxP=0, TIMx\_CCEN.CCxNP=0, TIMx\_BKDT.MOEN=1, TIMx\_CCEN.CCxEN=1,



### TIMx\_CCEN.CCxNEN=1.



Figure 8-26 Complementary output with dead-time insertion

User can set TIMx\_BKDT.DTGN to programme the dead-time delay for each of the channels.

### 8.3.13.1 Redirecting OCxREF to OCx or OCxN

User can set TIMx\_CCEN.CCxEN and TIMx\_CCEN.CCxNEN to re-directed OCxREF to the OCx output or to OCxN output, in output mode.

Here are two ways to use this function. When the complementary remains at its inactive level, user can use this function to send a specific waveform, such as PWM or static active level. User can also use this function to set both outputs in their inactive level or both outputs active and complementary with dead-time.

If user set TIMx\_CCEN.CCxEN=0 and TIMx\_CCEN.CCxNEN=1, it will not complemented, and OCxN will become active when OCxREF is high. On the other hand, if user set TIMx\_CCEN.CCxEN=1 and TIMx\_CCEN.CCxNEN=1, OCx will become active when OCxREF is high. On the contrary, OCxN will become active when OCxREF is high.



# 8.3.14 Break function

The output enable signals and inactive levels will be modified when setting the corresponding control bits when using the break function. However, the output of OCx and OCxN cannot at the active level at the same time no matter when, that is,  $(CCxP^OIx)^{(CCxNP^OIx)!=0}$ .

When multiple break signals are enabled, each break signal constitutes an OR logic. Here are some signal which can be the source of breaking.

- The break input pin
- A PVD failure event.
- Core Hardfault event.
- The output signal of the comparator (configured in the comparator module, high level break).
- By software through the TIMx\_EVTGEN.BGN.

The break circuit will be disable after reset. And the MOEN bit will be low. User can set TIMx\_BKDT.BKEN to enable the break function. The polarity of break input signal can be selected by setting TIMx\_BKDT.BKP. User can modify the TIMx\_BKDT.BKEN and TIMx\_BKDT.BKP at the same time. After user set the TIMx\_BKDT.BKEN and TIMx\_BKDT.BKP, there is 1 APB clock cycle delay before the option take effect. Therefore, user need to wait 1 APB clock cycle to read back the value of the written bit.

The falling edge of MOEN can be asynchronous, so between the actual signal and the synchronous control bit, there set a resynchronization circuit. This circuit will cause a delay between the asynchronous and the synchronous signal. When user set TIMx\_BKDT.MOEN while it is low, user need to insert a delay before reading the value. Because an asynchronous signal was written but user read the synchronous signal.

The behaviors that after a break occurs are as follow:

- TIMx\_BKDT.MOEN will be cleared asynchronously, and then the outputs will be put in inactive state, idle state or reset state. The state of output is selected by setting TIMx\_BKDT.OSSI. This will take effect even if the MCU oscillator is off.
- Once TIMx\_BKDT.MOEN=0, the output of each output channel will be driven with the level programmed in TIMx\_CTRL2.OIx. Timer will release the enable outputs(taken over by GPIO controller) if TIMx\_BKDT.OSSI=0, otherwise it will remains high.
- If user choose to use complementary outputs, the behaviors of TIM are as follow
  - Depends on the polarity, the outputs will be set in reset state first. It is an asynchronous option so it still works even if there is no clock provided to the timer.
  - The dead-time generator will reactivated if the timer clock is still provided, and drive the outputs according to the value of TIMx\_CTRL2.OIx and TIMx\_CTRL2.OIxN after the dead-time when (CCxP ^ OIx) ^ (CCxNP^OIxN)! = 0, that is, the OCx and OCxN still cannot be driven to active level at the same time. Note that the dead-time will be longer than usual because of the resynchronization on MOEN (almost 2 cycles of ck\_tim).
  - Timer will release the output control if TIMx\_BKDT.OSSI=0. Otherwise, if the enable output was high, it

137 / 319



will remain high. If it was low, it will become high when TIMx\_CCEN.CCxEN or TIMx\_CCEN.CCxNEN is high.

- If TIMx\_DINTEN.BIEN=1, when TIMx\_STS.BITF=1, an interrupt will be generated.
- If user set TIMx\_BKDT.AOEN, the TIMx\_BKDT.MOEN will be set automatically when the next UEV happened. User can use this to regulate. If user did not set TIMx\_BKDT.AOEN, the TIMx\_BKDT.MOEN will remain low until been set 1 again. At this situation, user can use this for security. User can connect the break input to thermal sensors, alarm for power drivers, or other security components.
- When the break input is active, TIMx\_BKDT.MOEN cannot be set automatically or by software at the same time, and the TIMx\_STS.BITF cannot be cleared. Because the break inputs are active on level.

To insure the security of application, the break circuit has the write protection function, and there is break input and output management too. It allow user to freeze some parameters, such as dead-time duration, OCx/OCxN polarities and state when disabled, OCxMD configurations, break enable and polarity. User can choose one of the 3 levels of protection to use by setting TIMx\_BKDT.LCKCFG. However, the TIMx\_BKDT.LCKCFG can only be written once after an MCU reset.

An example for output behavior in response to a break is as follow



### Figure 8-27 Output behavior in response to a break

## 8.3.15 Debug mode

When the microcontroller is in debug mode (the Cortex-M0 core halted), depending on the DBG\_CTRL.TIMx\_STOP

138 / 319



configuration in the PWR module, the TIMx counter can either continue to work normally or stop. For more details, see 3.4.9.

# 8.3.16 TIMx and external trigger synchronization

TIMx timers can be synchronized by a trigger in slave modes (reset, trigger and gated).

### 8.3.16.1 Slave mode: Reset mode

In reset mode, the trigger event can reset the counter and the prescaler updates the preload registers TIMx\_AR, TIMx\_CCDATx, and generates the update event UEV (TIMx\_CTRL1.UPRS=0).

The following is an example of a reset mode:

1. Channel 1 is configured as input to detect the rising edge of TI1 (TIMx\_CCMOD1.CC1SEL=01, TIMx\_CCEN.CC1P=0);

2. The slave mode is selected as reset mode (TIMx\_SMCTRL.SMSEL=100), and the trigger input is selected as TI1 (TIMx\_SMCTRL.TSEL=101);

3. Start counter(TIMx\_CTRL1.CNTEN = 1).

After starting the timer, when TI1 detects a rising edge, the counter resets and restarts counting, and the trigger flag is set (TIMx\_STS.TITF=1);

The delay between the rising edge on TI1 and the actual reset of the counter is due to the resynchronization circuit on TI1 input.

### Figure 8-28 Control circuit in reset mode



### 8.3.16.2 Slave mode: Trigger mode

In trigger mode, the trigger event (rising edge/falling edge) of the input port can trigger the counter to start counting.



The following is an example of a trigger pattern:

1. Channel 2 is configured as input to detect the rising edge of TI2 (TIMx\_CCMOD1.CC2SEL=01, TIMx CCEN.CC2P=0);

2. Select from mode to trigger mode (TIMx\_SMCTRL.SMSEL=110), select TI2 for trigger input (TIMx\_SMCTRL.TSEL=110);

When TI2 detects a rising edge, the counter starts counting, and the trigger flag is set (TIMx\_STS.TITF=1);

The delay between the rising edge on TI2 and the actual start of the counter is due to the resynchronization circuit on TI2 input.

#### Figure 8-29 Control circuit in Trigger mode



### 8.3.16.3 Slave mode: Gated mode

In gate control mode, the level polarity of the input port can control whether the counter counts.

The following is an example of a gated pattern:

1. Channel 1 is configured as input detection active low on TI1 (TIMx\_CCMOD1.CC1SEL = 01, TIMx\_CCEN.CC1P = 1);

2. Select the slave mode as the gated mode (TIMx\_SMCTRL.SMSEL = 101), and select TI1 as the trigger input (TIMx\_SMCTRL.TSEL = 101);

3. Start counter(TIMx\_CTRL1.CNTEN = 1).

When TI1 detects that the level changes from low to high, the counter stops counting, and when TI1 detects that the level changes from high to low, the counter starts counting, and the trigger flag will be set when it starts or stops counting (TIMx\_STS.TITF = 1);

The delay between the rising edge on TI1 and the actual stop of the counter is due to the resynchronization circuit on TI1 input.



#### Figure 8-30 Control circuit in Gated mode



### 8.3.16.4 Slave mode: Trigger Mode + External Clock Mode 2

In reset mode, trigger mode and gate control mode, the counter clock can be selected as external clock mode 2, and the ETR signal is used as the external clock source input. At this time, the trigger selection needs to select non-ETRF (TIMx\_SMCTRL.TSEL=111).

Here is an example:

1. Channel 1 is configured as input to detect the rising edge of TI1 (TIMx\_CCMOD1.CC1SEL=01, TIMx\_CCEN.CC1P=0);

2. Enable external clock mode 2 (TIMx\_SMCTRL.EXCEN=1), select rising edge for external trigger polarity (TIMx\_SMCTRL.EXTP=0), select slave mode as trigger mode (TIMx\_SMCTRL.SMSEL=110), select TI1 for trigger input (TIMx\_SMCTRL.TSEL=101);

When TI1 detects a rising edge, the counter starts counting on the rising edge of ETR, and the trigger flag is set (TIMx\_STS.TITF=1);







## 8.3.17 Timer synchronization

All TIM timers are internally connected for timer synchronization or chaining. For more details, see 9.3.14.

## 8.3.18 6-step PWM generation

In order to modify the configuration of all channels at the same time, the configuration of the next step can be set in advance (the preloaded bits are OCxMD, CCxEN and CCxNEN). When a COM commutation event occurs, the OCxMD, CCxEN, and CCxNEN preload bits are transferred to the shadow register bits.

COM commutation event generation method:

- 1. The software sets TIMx\_EVTGEN.CCUDGN;
- 2. Generated by hardware on the rising edge of TRGI;

When a COM commutation event occurs, the TIMx\_STS.COMITF flag will be set, enabling interrupts (TIMx\_DINTEN.COMIEN) will generate interrupts.

The following figure shows the output timing diagram of OCx and OCxN when a COM commutation event occurs in three different configurations:





#### Figure 8-32 6-step PWM generation, COM example (OSSR=1)

# **8.4** TIMx register description(x=1)

# 8.4.1 **Register Overview**

#### Table 8-1 Register overview

| Offset | Register    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24       | 23       | 22 | 21 | 20 | 19 | 18 | 17     | 16     | 15       | 14       | 13         | 12         | 11    | 10       | 6         | 8         | 7      | 6 | 5           | 4   | 3        | 0      | 1          | 0      |
|--------|-------------|----|----|----|----|----|----|----|----------|----------|----|----|----|----|----|--------|--------|----------|----------|------------|------------|-------|----------|-----------|-----------|--------|---|-------------|-----|----------|--------|------------|--------|
| 000h   | TIMx_CTRL1  |    |    |    |    |    |    |    | Reserved |          |    |    |    |    |    | PBKPEN | LBKPEN | CLRSEL   | Reserved | Reserved   | Reserved   | CISEL | IOMBKPEN |           | CLKD[1:0] | ARPEN  |   | CAMSEL[1:0] | DIR | ONEPM    | UPRS   | UPDIS      | CNTEN  |
|        | Reset Value |    |    |    |    |    |    |    |          |          |    |    |    |    |    | 0      | 0      | 0        |          |            |            | 0     | 0        | 0         | 0         | 0      | 0 | 0           | 0   | 0        | 0      | 0          | 0      |
| 004h   | TIMx_CTRL2  |    |    |    |    |    |    |    | Reserved |          |    |    |    |    |    |        | OI5    | Reserved | 014      | OI3N       | 013        | 012N  | 012      | OUN       | 011       | TIISEL |   | MMSEL[2:0]  |     | Reserved | CCUSEL | Reserved   | CCPCTL |
|        | Reset Value |    |    |    |    |    |    |    |          |          |    |    |    |    |    |        | 0      |          | 0        | 0          | 0          | 0     | 0        | 0         | 0         | 0      | 0 | 0           | 0   |          | 0      |            | 0      |
| 008h   | TIMx_SMCTRL |    |    |    |    |    |    |    |          | Reserved |    |    |    |    |    |        |        | EXTP     | EXCEN    | IV LISGTVE | [0:1]S11V3 |       |          | [0:c]11VJ |           | MSMD   |   | TSEL[2:0]   |     | Reserved |        | SMSEL[2:0] |        |
|        | Reset Value |    |    |    |    |    |    |    |          |          |    |    |    |    |    |        |        | 0        | 0        | 0          | 0          | 0     | 0        | 0         | 0         | 0      | 0 | 0           | 0   |          | 0      | 0          | 0      |

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



www.nationstech.com

| 00Ch  | TIMx_DINTEN                | Reserved  | BIEN<br>TIEN<br>TIEN<br>COMIEN<br>COMIEN<br>CC4IEN<br>CC1IEN<br>UIEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|----------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ooen  |                            | Ress      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | Reset Value                | r.        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 010h  | TIMx_STS                   | Reserved  | Reserved<br>CC40CF<br>CC30CF<br>CC30CF<br>CC30CF<br>CC10CF<br>Reserved<br>BITTF<br>TTTF<br>CC10CF<br>CC4TTF<br>CC4TTF<br>CC4TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3TTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC3CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC3CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>CC2CTF<br>C |
|       | Reset Value                | 0         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 014h  | TIMx_EVTGEN                | Reserved  | BGN       TGN       CCUDGN       CC3GN       CC3GN       CC3GN       CC3GN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | Reset Value                |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | TIMx_CCMOD1                | Reserved  | OC2CEN<br>OC2M[2:0]<br>OC2PEN<br>OC2PEN<br>OC2PEN<br>OC2PEN<br>OC1PEN<br>OC1DEN<br>OC1PEN<br>OC1PEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 018h  | Reset Value                |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | TIMx_CCMOD1                | Reserved  | IC2F[3:0]<br>IC2PSC[1:0]<br>IC2PSC[1:0]<br>IC1F[3:0]<br>IC1F[3:0]<br>IC1F[3:0]<br>IC1F[3:0]<br>IC1F[3:0]<br>IC1F[3:0]<br>IC1F[3:0]<br>IC1F[3:0]<br>IC1F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC2F[3:0]<br>IC                                                                                                                                                                                                                                                                         |
|       | Reset Value                |           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       | TIMx_CCMOD2                | Reserved  | 0C4CEN<br>0C4M[2:0]<br>0C4PEN<br>0C4FEN<br>0C4FEN<br>0C4FEN<br>0C4FEN<br>0C4FEN<br>0C3FEN<br>0C3PEN<br>0C3FEN<br>0C3FEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| )1Ch  | Reset Value                |           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       | TIMx_CCMOD2                | Reserved  | IC4F[3:0]<br>IC4FSC[1:0]<br>CC4SEL[1:0]<br>IC3F[3:0]<br>IC3F[3:0]<br>IC3FSC[1:0]<br>IC3FSC[1:0]<br>CC3SEL[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | Reset Value                |           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| )20h  | TIMx_CCEN                  | 0 0 CCSBN | Reserved           a         CC4P           a         CC4P           a         CC4PN           a         CC3NP           a         CC3NPN           a         CC2NPN           a         CC2NPN           a         CC1NPN           a         CC1NPN           a         CC1NPN           a         CC1NPN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | Reset Value<br>TIMx_CNT    |           | CNT[15:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| )24h  | Reset Value                | Reserved  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| )28h  | TIMx_PSC<br>Reset Value    | Reserved  | PSC[15:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| )2Ch  | TIMx_AR                    | Reserved  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 030h  | Reset Value<br>TIMx_REPCNT | Reserved  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       | Reset Value                |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 034h  | TIMx_CCDAT1<br>Reset Value | Reserved  | CCDAT1[15:0]           0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 <t< td=""></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 038h  | TIMx_CCDAT2                | Reserved  | CCDAT2[15:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | Reset Value<br>TIMx_CCDAT3 |           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 03Ch  | Reset Value                | Reserved  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 040h  | TIMx_CCDAT4<br>Reset Value | Reserved  | CCDAT4[15:0]           0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 <t< td=""></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 044h  | TIMx_BKDT                  | Reserved  | WOEN<br>WOEN<br>WOEN<br>WOEN<br>WOEN<br>WOEN<br>WOEN<br>WOEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | Reset Value                |           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 054h  | TIMx_CCMOD3                | Reserved  | OCSCEN<br>OCSCEN<br>OCSPEN<br>OCSPEN<br>OCSFEN<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0.503 | Reset Value                | <b>D</b>  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 058h  | TIMx_CCDAT5                | Reserved  | CCDAT5[15:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Nations Technologies Inc.

Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



## 8.4.2 Control register 1 (TIMx\_CTRL1)

Offset address: 0x00

Reset value: 0x0000 0000

| 31     |    |          |    | -     |              |          |        |       |      |         |     |       | 18   | 17      | 16           |
|--------|----|----------|----|-------|--------------|----------|--------|-------|------|---------|-----|-------|------|---------|--------------|
|        | 1  |          | 1  | 1     |              | Reserved |        |       |      |         | 1   | 1     |      | PBKPEN  | LOCKUP<br>EN |
| 15     | 14 |          | 12 | 11    | 10           | 9        | 8      | 7     | 6    | 5       | 4   | 3     | 2    | rw<br>1 | rw<br>0      |
| CLRSEL |    | Reserved | 1  | C1SEL | IOM<br>BKPEN | CLKI     | D[1:0] | ARPEN | CAMS | EL[1:0] | DIR | ONEPM | UPRS | UPDIS   | CNTEN        |
| rw     |    |          |    | rw    | rw           | r        | w      | rw    | r    | w       | rw  | rw    | rw   | rw      | rw           |

| Bit field | Name        | Description                                                                             |
|-----------|-------------|-----------------------------------------------------------------------------------------|
| 31:18     | Reserved    | Reserved, the reset value must be maintained                                            |
| 17        | PBKPEN      | PVD as BKP enable                                                                       |
|           |             | 0: Disable                                                                              |
|           |             | 1: Enable                                                                               |
| 16        | LBKPEN      | LockUp as BKP enable                                                                    |
|           |             | 0: Disable                                                                              |
|           |             | 1: Enable                                                                               |
| 15        | CLRSEL      | OCxREF clear selection                                                                  |
|           |             | 0: Select the external OCxREF clear from ETR                                            |
|           |             | 1: Select the internal OCxREF clear from comparator                                     |
| 14:12     | Reserved    | Reserved, the reset value must be maintained                                            |
| 11        | C1SEL       | Channel 1 selection                                                                     |
|           |             | 0: Select external CH1 signal from IOM                                                  |
|           |             | 1: Select internal CH1 signal from COMP                                                 |
| 10        | IOMBKPEN    | Enabling IOM as BKP                                                                     |
|           |             | 0: Enable                                                                               |
|           |             | 1: Disable                                                                              |
| 9:8       | CLKD[1:0]   | Clock division                                                                          |
|           |             | CLKD[1:0] indicates the division ratio between CK_INT (timer clock) and DTS (clock used |
|           |             | for dead-time generator and 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, do not use this configuration                                             |
| 7         | ARPEN       | ARPEN: Auto-reload preload enable                                                       |
|           |             | 0: Shadow register disable for TIMx_AR register                                         |
|           |             | 1: Shadow register enable for TIMx_AR register                                          |
| 6:5       | CAMSEL[1:0] | Center-aligned mode selection                                                           |



| Bit field  | Name  | Description                                                                                        |  |  |  |  |  |  |
|------------|-------|----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|            |       | 00: Edge-aligned mode. TIMx_CTRL1.DIR specifies up-counting or down-counting.                      |  |  |  |  |  |  |
|            |       | 01: Center-aligned mode 1. The counter counts in center-aligned mode, and the output               |  |  |  |  |  |  |
|            |       | compare interrupt flag bit is set to 1 when down-counting.                                         |  |  |  |  |  |  |
|            |       | 10: Center-aligned mode 2. The counter counts in center-aligned mode, and the output               |  |  |  |  |  |  |
|            |       | compare interrupt flag bit is set to 1 when up-counting.                                           |  |  |  |  |  |  |
|            |       | 11: Center-aligned mode 3. The counter counts in center-aligned mode, and the output               |  |  |  |  |  |  |
|            |       | compare interrupt flag bit is set to 1 when up-counting or down-counting.                          |  |  |  |  |  |  |
|            |       | Note: Switching from edge-aligned mode to center-aligned mode is not allowed when the              |  |  |  |  |  |  |
|            |       | counter is still enabled ( $TIMx\_CTRL1.CNTEN = 1$ ).                                              |  |  |  |  |  |  |
| 1          | DIR   | Direction                                                                                          |  |  |  |  |  |  |
|            |       | 0: Up-counting                                                                                     |  |  |  |  |  |  |
|            |       | 1: Down-counting                                                                                   |  |  |  |  |  |  |
|            |       | Note: This bit is read-only when the counter is configured in center-aligned mode.                 |  |  |  |  |  |  |
| 3 C<br>2 U | ONEPM | One-pulse mode                                                                                     |  |  |  |  |  |  |
|            |       | 0: Disable one-pulse mode, the counter counts are not affected when an update event occurs.        |  |  |  |  |  |  |
|            |       | 1: Enable one-pulse mode, the counter stops counting when the next update event occurs             |  |  |  |  |  |  |
|            |       | (clearing TIMx_CTRL1.CNTEN bit)                                                                    |  |  |  |  |  |  |
| 2          | UPRS  | Update request source                                                                              |  |  |  |  |  |  |
|            |       | This bit is used to select the UEV event sources by software.                                      |  |  |  |  |  |  |
|            |       | 0: If update interrupt is enabled, any of the following events will generate an update interrupt : |  |  |  |  |  |  |
|            |       | <ul> <li>Counter overflow/underflow</li> </ul>                                                     |  |  |  |  |  |  |
|            |       | <ul> <li>The TIMx_EVTGEN.UDGN bit is set</li> </ul>                                                |  |  |  |  |  |  |
|            |       | <ul> <li>Update generation from the slave mode controller</li> </ul>                               |  |  |  |  |  |  |
|            |       | 1: If update interrupt is enabled, only counter overflow/underflow will generate update            |  |  |  |  |  |  |
|            |       | interrupt                                                                                          |  |  |  |  |  |  |
| 1          | UPDIS | Update disable                                                                                     |  |  |  |  |  |  |
|            |       | This bit is used to enable/disable the Update event (UEV) events generation by software.           |  |  |  |  |  |  |
|            |       | 0: Enable UEV. UEV will be generated if one of following condition been fulfilled:                 |  |  |  |  |  |  |
|            |       | <ul> <li>Counter overflow/underflow</li> </ul>                                                     |  |  |  |  |  |  |
|            |       | <ul> <li>The TIMx_EVTGEN.UDGN bit is set</li> </ul>                                                |  |  |  |  |  |  |
|            |       | <ul> <li>Update generation from the slave mode controller</li> </ul>                               |  |  |  |  |  |  |
|            |       | Shadow registers will update with preload value.                                                   |  |  |  |  |  |  |
|            |       | 1: UEV disabled. No update event is generated, and the shadow registers (AR, PSC, and              |  |  |  |  |  |  |
|            |       | CCDATx) keep their values. If the TIMx_EVTGEN.UDGN bit is set or a hardware reset is               |  |  |  |  |  |  |
|            |       | issued by the slave mode controller, the counter and prescaler are reinitialized.                  |  |  |  |  |  |  |
| )          | CNTEN | Counter Enable                                                                                     |  |  |  |  |  |  |
|            |       | 0: Disable counter                                                                                 |  |  |  |  |  |  |
|            |       | 1: Enable counter                                                                                  |  |  |  |  |  |  |
|            |       | <i>Note: external clock, gating mode can only work after TIMx_CTRL1.CNTEN bit is set in the</i>    |  |  |  |  |  |  |
|            |       | software. Trigger mode can automatically set TIMx_CTRL1.CNTEN bit by hardware.                     |  |  |  |  |  |  |



# 8.4.3 Control register 2 (TIMx\_CTRL2)

Offset address: 0x04

Reset value: 0x0000 0000



| Bit field | Name       | Description                                                                                    |  |  |  |  |  |  |
|-----------|------------|------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 31:17     | Reserved   | Reserved, the reset value must be maintained                                                   |  |  |  |  |  |  |
| 16        | OI5        | Output idle state 5 (OC5 output). See TIMx_CTRL2.OI1 bit.                                      |  |  |  |  |  |  |
| 15        | Reserved   | Reserved, the reset value must be maintained                                                   |  |  |  |  |  |  |
| 14        | OI4        | Output idle state 4 (OC4 output). See TIMx_CTRL2.OI1 bit.                                      |  |  |  |  |  |  |
| 13        | OI3N       | Output idle state 3 (OC3N output). See TIMx_CTRL2.OI1N bits.                                   |  |  |  |  |  |  |
| 12        | OI3        | Output idle state 3 (OC3 output). See TIMx_CTRL2.OI1 bit.                                      |  |  |  |  |  |  |
| 11        | OI2N       | Output idle state 2 (OC2N output). See TIMx_CTRL2.OI1N bits.                                   |  |  |  |  |  |  |
| 10        | OI2        | Output idle state 2 (OC2 output). See TIMx_CTRL2.OI1 bit.                                      |  |  |  |  |  |  |
| 9         | OI1N       | Output Idle state 1 (OC1N Output)                                                              |  |  |  |  |  |  |
|           |            | 0: When TIMx_BKDT.MOEN = 0, after dead-time $OC1N = 0$                                         |  |  |  |  |  |  |
|           |            | 1: When $TIMx_BKDT.MOEN = 0$ , after dead-time $OC1N = 1$                                      |  |  |  |  |  |  |
| 8         | OI1        | Output Idle state 1                                                                            |  |  |  |  |  |  |
|           |            | 0: When TIMx_BKDT.MOEN = 0, if OC1N is implemented, after dead-time $OC1 = 0$                  |  |  |  |  |  |  |
|           |            | 1: When TIMx_BKDT.MOEN = 0, if OC1N is implemented, after dead-time $OC1 = 1$                  |  |  |  |  |  |  |
| 7         | TI1SEL     | TI1 selection                                                                                  |  |  |  |  |  |  |
|           |            | 0: TIMx_CH1 pin connected to TI1 input.                                                        |  |  |  |  |  |  |
|           |            | 1: TIMx_CH1, TIMx_CH2, and TIMx_CH3 pins are XOR connected to the TI1 input.                   |  |  |  |  |  |  |
| 6:4       | MMSEL[2:0] | Master Mode Selection                                                                          |  |  |  |  |  |  |
|           |            | These 3 bits (TIMx_CTRL2. MMSEL [2:0]) are used to select the synchronization information      |  |  |  |  |  |  |
|           |            | (TRGO) sent to the slave timer in the master mode. Possible combinations are as follows:       |  |  |  |  |  |  |
|           |            | 000: Reset –When the TIMx_EVTGEN.UDGN is set or a reset is generated by the slave mode         |  |  |  |  |  |  |
|           |            | controller, a TRGO pulse occurs. And in the latter case, the signal on TRGO is delayed         |  |  |  |  |  |  |
|           |            | compared to the actual reset.                                                                  |  |  |  |  |  |  |
|           |            | 001: Enable - The TIMx_CTRL1.CNTEN bit is used as the trigger output (TRGO). Sometimes         |  |  |  |  |  |  |
|           |            | you need to start multiple timers at the same time or enable slave timer for a period of time. |  |  |  |  |  |  |
|           |            | The counter enable signal is set when TIMx_CTRL1.CNTEN bit is set or the trigger input in      |  |  |  |  |  |  |
|           |            | gated mode is high.                                                                            |  |  |  |  |  |  |
|           |            | When the counter enable signal is controlled by the trigger input, there is a delay on TRGO    |  |  |  |  |  |  |
|           |            | except if the master/slave mode is selected (see the description of the TIMx_SMCTRL.MSMD       |  |  |  |  |  |  |
|           |            | bit).                                                                                          |  |  |  |  |  |  |



| Bit field | Name     | Description                                                                                    |  |  |  |  |  |  |
|-----------|----------|------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|           |          | 010: Update - The update event is selected as the trigger output (TRGO). For example, a master |  |  |  |  |  |  |
|           |          | timer clock can be used as a slave timer prescaler.                                            |  |  |  |  |  |  |
|           |          | 011: Compare pulse - Triggers the output to send a positive pulse (TRGO) when the              |  |  |  |  |  |  |
|           |          | TIMx_STS.CC1ITF is to be set (even if it is already high), when a capture or a comparison      |  |  |  |  |  |  |
|           |          | succeeds.                                                                                      |  |  |  |  |  |  |
|           |          | 100: Compare - OC1REF signal is used as the trigger output (TRGO).                             |  |  |  |  |  |  |
|           |          | 101: Compare - OC2REF signal is used as the trigger output (TRGO).                             |  |  |  |  |  |  |
|           |          | 110: Compare - OC3REF signal is used as the trigger output (TRGO).                             |  |  |  |  |  |  |
|           |          | 111: Compare - OC4REF signal is used as the trigger output (TRGO).                             |  |  |  |  |  |  |
| 3         | Reserved | Reserved, the reset value must be maintained                                                   |  |  |  |  |  |  |
| 2         | CCUSEL   | Capture/compare control update selection                                                       |  |  |  |  |  |  |
|           |          | 0: If TIMx_CTRL2.CCPCTL = 1, they can only be updated by setting CCUDGN bits                   |  |  |  |  |  |  |
|           |          | 1: If TIMx_CTRL2.CCPCTL = 1, they can be updated by setting CCUDGN bits or a rising edge       |  |  |  |  |  |  |
|           |          | on TRGI.                                                                                       |  |  |  |  |  |  |
|           |          | Note: This bit only applied to channels with complementary outputs.                            |  |  |  |  |  |  |
| 1         | Reserved | Reserved, the reset value must be maintained                                                   |  |  |  |  |  |  |
| 0         | CCPCTL   | Capture/ Compare preloaded control                                                             |  |  |  |  |  |  |
|           |          | 0: No preloading of CCxEN, CCxNEN and OCxMD bits occurs.                                       |  |  |  |  |  |  |
|           |          | 1: Preloading of CCxEN, CCxNEN and OCxMD bits occurs. they are updated only when a             |  |  |  |  |  |  |
|           |          | commutation event COM occurs (TIMx_EVTGEN.CCUDGN bit set or rising edge on TRGI                |  |  |  |  |  |  |
|           |          | depending on CCUSEL bit)                                                                       |  |  |  |  |  |  |
|           |          | Note: This bit only applied to channels with complementary outputs.                            |  |  |  |  |  |  |

# 8.4.4 Slave mode control register (TIMx\_SMCTRL)

### Offset address: 0x08

Reset value: 0x0000

| 15   | 14    | 13 12      | 11 |           | 8 | 7    | 6  | 4       | 3        | 2 | 0          |
|------|-------|------------|----|-----------|---|------|----|---------|----------|---|------------|
| EXTP | EXCEN | EXTPS[1:0] |    | EXTF[3:0] | 1 | MSMD | TS | EL[2:0] | Reserved | 5 | SMSEL[2:0] |
| rw   | rw    | rw         |    | rw        |   | rw   |    | rw      |          |   | rw         |

| Bit field | Name  | Description                                                                                       |
|-----------|-------|---------------------------------------------------------------------------------------------------|
| 15        | EXTP  | External trigger polarity                                                                         |
|           |       | This bit is used to select whether the trigger operation is to use ETR or the inversion of ETR.   |
|           |       | 0: ETR active at high level or rising edge.                                                       |
|           |       | 1: ETR active at low level or falling edge.                                                       |
| 14        | EXCEN | External clock enable                                                                             |
|           |       | This bit is used to enable external clock mode 2, and the counter is driven by any active edge on |
|           |       | the ETRF signal in this mode.                                                                     |
|           |       | 0: External clock mode 2 disable.                                                                 |
|           |       | 1: External clock mode 2 enable.                                                                  |



| Bit field | Name       | Description                                                                                      |
|-----------|------------|--------------------------------------------------------------------------------------------------|
|           |            | Note 1: When external clock mode 1 and external clock mode 2 are enabled at the same time, the   |
|           |            | input of the external clock is ETRF.                                                             |
|           |            | Note 2: The following slave modes can be used simultaneously with external clock mode 2: reset   |
|           |            | mode, gated mode and trigger mode; However, TRGI cannot connect to ETRF                          |
|           |            | $(TIMx\_SMCTRL.TSEL \neq '111').$                                                                |
|           |            | Note 3: Setting the TIMx_SMCTRL.EXCEN bit has the same effect as selecting external clock        |
|           |            | mode 1 and connecting TRGI to ETRF (TIMx_SMCTRL.SMSEL = 111 and TIMx_SMCTRL.TSEL                 |
|           |            | = 111).                                                                                          |
| 13:12     | EXTPS[1:0] | External trigger prescaler                                                                       |
|           |            | The frequency of the external trigger signal ETRP must be at most 1/4 of TIMxCLK frequency.      |
|           |            | When a faster external clock is input, a prescaler can be used to reduce the frequency of ETRP.  |
|           |            | 00: Prescaler disable                                                                            |
|           |            | 01: ETRP frequency divided by 2                                                                  |
|           |            | 10: ETRP frequency divided by 4                                                                  |
|           |            | 11: ETRP frequency divided by 8                                                                  |
| 11:8      | EXTF[3:0]  | External trigger filter                                                                          |
|           |            | These bits are used to define the frequency at which the ETRP signal is sampled and the          |
|           |            | bandwidth of the ETRP digital filtering. In effect, the digital filter is an event counter that  |
|           |            | generates a validate output after consecutive N events are recorded.                             |
|           |            | 0000: No filter, sampling at f <sub>DTS</sub>                                                    |
|           |            | 0001: $f_{SAMPLING} = f_{CK\_INT}$ , N = 2                                                       |
|           |            | 0010: $f_{SAMPLING} = f_{CK_INT}$ , N = 4                                                        |
|           |            | 0011: $f_{SAMPLING} = f_{CK_INT}, N = 8$                                                         |
|           |            | 0100: $f_{SAMPLING} = f_{DTS}/2$ , N = 6                                                         |
|           |            | 0101: $f_{SAMPLING} = f_{DTS}/2$ , N = 8                                                         |
|           |            | 0110: $f_{SAMPLING} = f_{DTS}/4$ , N = 6                                                         |
|           |            | 0111: $f_{SAMPLING} = f_{DTS}/4$ , N = 8                                                         |
|           |            | 1000: $f_{SAMPLING} = f_{DTS}/8$ , N = 6                                                         |
|           |            | 1001: $f_{SAMPLING} = f_{DTS}/8$ , N = 8                                                         |
|           |            | 1010: $f_{SAMPLING} = f_{DTS}/16$ , N = 5                                                        |
|           |            | $1011: f_{SAMPLING} = f_{DTS}/16, N = 6$                                                         |
|           |            | 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: $f_{SAMPLING} = f_{DTS}/32, N = 8$                                                         |
| 7         | MSMD       | Master/ Slave mode                                                                               |
|           |            | 0: No action                                                                                     |
|           |            | 1: Events on the trigger input (TRGI) are delayed to allow a perfect synchronization between the |
|           |            | current timer (via TRGO) and its slaves. This is useful when several timers are required to be   |
|           |            | synchronized to a single external event.                                                         |



| Bit field | Name       | Description                                                                                          |  |  |  |  |  |  |
|-----------|------------|------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 6:4       | TSEL[2:0]  | Trigger selection                                                                                    |  |  |  |  |  |  |
|           |            | These 3 bits are used to select the trigger input of the synchronous counter.                        |  |  |  |  |  |  |
|           |            | 000: Internal trigger 0 (ITR0) 100: TI1 edge detector (TI1F_ED)                                      |  |  |  |  |  |  |
|           |            | 001: Internal trigger 1 (ITR1) 101: Filtered timer input 1 (TI1FP1)                                  |  |  |  |  |  |  |
|           |            | 010: Internal trigger 2 (ITR2) 110: Filtered timer input 2 (TI2FP2)                                  |  |  |  |  |  |  |
|           |            | 011: Internal trigger 3 (ITR3) 111: External triggered Input (ETRF)                                  |  |  |  |  |  |  |
|           |            | For more details on ITRx, see Table 8-2 below.                                                       |  |  |  |  |  |  |
|           |            | Note: These bits must be changed only when not in use (e. g. TIMx_SMCTRL.SMSEL=000) to               |  |  |  |  |  |  |
|           |            | avoid false edge detection at the transition.                                                        |  |  |  |  |  |  |
| 3         | Reserved   | Reserved, the reset value must be maintained                                                         |  |  |  |  |  |  |
| 2:0       | SMSEL[2:0] | Slave mode selection                                                                                 |  |  |  |  |  |  |
|           |            | When an external signal is selected, the active edge of the trigger signal (TRGI) is linked to the   |  |  |  |  |  |  |
|           |            | selected external input polarity (see input control register and control register description)       |  |  |  |  |  |  |
|           |            | 000: Disable slave mode. If TIMx_CTRL1.CNTEN = 1, the prescaler is driven directly by the            |  |  |  |  |  |  |
|           |            | internal clock.                                                                                      |  |  |  |  |  |  |
|           |            | 001: reserved.                                                                                       |  |  |  |  |  |  |
|           |            | 010: reserved.                                                                                       |  |  |  |  |  |  |
|           |            | 011: reserved.                                                                                       |  |  |  |  |  |  |
|           |            | 100: Reset mode. On the rising edge of the selected trigger input (TRGI), the counter is             |  |  |  |  |  |  |
|           |            | reinitialized and the shadow register is updated.                                                    |  |  |  |  |  |  |
|           |            | 101: Gated mode. When the trigger input (TRGI) is high, the clock of the counter is enabled. Once    |  |  |  |  |  |  |
|           |            | the trigger input becomes low, the counter stops counting, but is not reset. In this mode, the start |  |  |  |  |  |  |
|           |            | and stop of the counter are controlled.                                                              |  |  |  |  |  |  |
|           |            | 110: Trigger mode. When a rising edge occurs on the trigger input (TRGI), the counter is started     |  |  |  |  |  |  |
|           |            | but not reset. In this mode, only the start of the counter is controlled.                            |  |  |  |  |  |  |
|           |            | 111: External clock mode 1. The counter is clocked by the rising edge of the selected trigger input  |  |  |  |  |  |  |
|           |            | (TRGI).                                                                                              |  |  |  |  |  |  |
|           |            | Note: Do not use gated mode if TIIF_ED is selected as the trigger input                              |  |  |  |  |  |  |
|           |            | (TIMx_SMCTRL.TSEL=100). This is because TI1F_ED outputs a pulse for each TI1F transition,            |  |  |  |  |  |  |
|           |            | whereas gated mode checks the level of the triggered input.                                          |  |  |  |  |  |  |

| Table 8-2 TIMx interna | l trigger connection |
|------------------------|----------------------|
|------------------------|----------------------|

| Slave timer | <b>ITR0 (TSEL = 000)</b> | ITR1 (TSEL = 001) | ITR2 (TSEL = 010) | ITR3 (TSEL = 011) |
|-------------|--------------------------|-------------------|-------------------|-------------------|
| TIM1        | NA                       | NA                | TIM3              | NA                |

# 8.4.5 Interrupt enable registers (TIMx\_DINTEN)

Offset address: 0x0C

Reset value: 0x0000



| 15 |          |  |  |   | 8 | 7    | 6    | 5      | 4      | 3      | 2      | 1      | 0    |
|----|----------|--|--|---|---|------|------|--------|--------|--------|--------|--------|------|
|    | Reserved |  |  |   |   | BIEN | TIEN | COMIEN | CC4IEN | CC3IEN | CC2IEN | CC1IEN | UIEN |
|    |          |  |  | 1 |   | rw   | rw   | rw     | rw     | rw     | rw     | rw     | rw   |

| Bit field | Name     | Description                                  |
|-----------|----------|----------------------------------------------|
| 15:8      | Reserved | Reserved, the reset value must be maintained |
| 7         | BIEN     | Break interrupt enable                       |
|           |          | 0: Disable break interrupt                   |
|           |          | 1: Enable break interrupt                    |
| 6         | TIEN     | Trigger interrupt enable                     |
|           |          | 0: Disable trigger interrupt                 |
|           |          | 1: Enable trigger interrupt                  |
| 5         | COMIEN   | COM interrupt enable                         |
|           |          | 0: Disable COM interrupt                     |
|           |          | 1: Enable COM interrupt                      |
| 4         | CC4IEN   | Capture/Compare 4 interrupt enable           |
|           |          | 0: Disable capture/compare 4 interrupt       |
|           |          | 1: Enable capture/compare 4 interrupt        |
| 3         | CC3IEN   | Capture/Compare 3 interrupt enable           |
|           |          | 0: Disable capture/compare 3 interrupt       |
|           |          | 1: Enable capture/compare 3 interrupts       |
| 2         | CC2IEN   | Capture/Compare 2 interrupt enable           |
|           |          | 0: Disable capture/compare 2 interrupt       |
|           |          | 1: Enables capture/compare 2 interrupts      |
| 1         | CC1IEN   | Capture/Compare 1 interrupt enable           |
|           |          | 0: Disable capture/compare 1 interrupt       |
|           |          | 1: Enables capture/comparing 1 interrupt     |
| 0         | UIEN     | Update interrupt enable                      |
|           |          | 0: Disable update interrupt                  |
|           |          | 1: Enables update interrupt                  |

# 8.4.6 Status registers (TIMx\_STS)

#### Offset address: 0x10

#### Reset value: 0x0000 0000

| 31 |          |    |        |        |        |        | -        |       | -     |        |        |        |        | 17     | 16         |
|----|----------|----|--------|--------|--------|--------|----------|-------|-------|--------|--------|--------|--------|--------|------------|
|    | 1        |    |        | 1      |        | 1      | Reserved | 1     | 1     | 1      |        | 1      |        | 1      | CC5ITF     |
| 15 | ·        | 13 | 12     | 11     | 10     | 9      | 8        | 7     | 6     | 5      | 4      | 3      | 2      | 1      | rc_w0<br>0 |
|    | Reserved | 1  | CC4OCF | CC30CF | CC2OCF | CC10CF | Reserved | BITF  | TITF  | COMITF | CC4ITF | CC3ITF | CC2ITF | CC1ITF | UDITF      |
|    |          |    | rc_w0  | rc_w0  | rc_w0  | rc_w0  |          | rc_w0 | rc_w0 | rc_w0  | rc_w0  | rc_w0  | rc_w0  | rc_w0  | rc_w0      |



|        | Name     | Description                                                                                      |
|--------|----------|--------------------------------------------------------------------------------------------------|
| 31: 17 | Reserved | Reserved, the reset value must be maintained                                                     |
| 16     | CC5ITF   | Capture/Compare 5 interrupt flag                                                                 |
|        |          | See TIMx_STS.CC1ITF description.                                                                 |
| 15: 13 | Reserved | Reserved, the reset value must be maintained                                                     |
| 12     | CC40CF   | Capture/Compare 4 overcapture flag                                                               |
|        |          | See TIMx_STS.CC1OCF description.                                                                 |
| 11     | CC3OCF   | Capture/Compare 3 overcapture flag                                                               |
|        |          | See TIMx_STS.CC1OCF description.                                                                 |
| 10     | CC2OCF   | Capture/Compare 2 overcapture flags                                                              |
|        |          | See TIMx_STS.CC1OCF description.                                                                 |
| 9      | CC10CF   | Capture/Compare 1 overcapture flag                                                               |
|        |          | This bit is set by hardware only when the corresponding channel is configured in input capture   |
|        |          | mode. Cleared by software writing 0.                                                             |
|        |          | 0: No overcapture occurred                                                                       |
|        |          | 1: TIMx_STS.CC1ITF was already set when the value of the counter has been captured in the        |
|        |          | TIMx_CCDAT1 register.                                                                            |
| 8      | Reserved | Reserved, the reset value must be maintained                                                     |
| 7      | BITF     | Break interrupt flag                                                                             |
|        |          | This bit is set by hardware once the brake input is active. This bit is cleared by software when |
|        |          | the brake input becomes inactive.                                                                |
|        |          | 0: No break event occurred                                                                       |
|        |          | 1: An active level has been detected                                                             |
| 6      | TITF     | Trigger interrupt flag                                                                           |
|        |          | This bit is set by hardware when an active edge is detected on the TRGI input when the slave     |
|        |          | mode controller is in a mode other than gated. This bit is set by hardware when any edge in      |
|        |          | gated mode is detected. This bit is cleared by software.                                         |
|        |          | 0: No trigger event occurred                                                                     |
|        |          | 1: Trigger interrupt occurred                                                                    |
| 5      | COMITF   | COM interrupt flag                                                                               |
|        |          | This bit is set by hardware once a COM event is generated (when TIMx_CCEN.CCxEN,                 |
|        |          | TIMx_CCEN.CCxNEN, TIMx_CCMOD1.OCxMD have been updated). This bit is cleared by                   |
|        |          | software.                                                                                        |
|        |          | 0: No COM event occurred                                                                         |
|        |          | 1: COM interrupt pending                                                                         |
| 4      | CC4ITF   | Capture/Compare 4 interrupt flag                                                                 |
|        |          | See TIMx_STS.CC1ITF description.                                                                 |
| 3      | CC3ITF   | Capture/Compare 3 interrupt flag                                                                 |
|        |          | See TIMx_STS.CC1ITF description.                                                                 |
| 2      | CC2ITF   | Capture/Compare 2 interrupt flag                                                                 |
|        |          | See TIMx_STS.CC1ITF description.                                                                 |
| 1      | CC1ITF   | Capture/Compare 1 interrupt flag                                                                 |
|        |          | When the corresponding channel of CC1 is in output mode:                                         |

152/319



| Bit field | Name  | Description                                                                                      |
|-----------|-------|--------------------------------------------------------------------------------------------------|
|           |       | Except in center-aligned mode, this bit is set by hardware when the counter value is the same as |
|           |       | the compare value (see TIMx_CTRL1.CAMSEL bit description). This bit is cleared by                |
|           |       | software.                                                                                        |
|           |       | 0: No match occurred.                                                                            |
|           |       | 1: The value of TIMx_CNT is the same as the value of TIMx_CCDAT1.                                |
|           |       | When the value of TIMx_CCDAT1 is greater than the value of TIMx_AR, the                          |
|           |       | TIMx_STS.CC1ITF bit will go high if the counter overflows (in up-counting and up/down-           |
|           |       | counting modes) and underflows in down-counting mode.                                            |
|           |       | When the corresponding channel of CC1 is in input mode:                                          |
|           |       | This bit is set by hardware when the capture event occurs. This bit is cleared by software or by |
|           |       | reading TIMx_CCDAT1.                                                                             |
|           |       | 0: No input capture occurred.                                                                    |
|           |       | 1: Input capture occurred. Counter value has captured in the TIMx_CCDAT1. An edge with the       |
|           |       | same polarity as selected has been detected on IC1.                                              |
| 0         | UDITF | Update interrupt flag                                                                            |
|           |       | This bit is set by hardware when an update event occurs under the following conditions:          |
|           |       | - When TIMx_CTRL1.UPDIS = 0, and repeat counter value overflow or underflow (An                  |
|           |       | update event is generated when the repeat counter equals 0).                                     |
|           |       | - When TIMx_CTRL1.UPRS = 0, TIMx_CTRL1.UPDIS = 0, and set the                                    |
|           |       | TIMx_EVTGEN.UDGN bit by software to reinitialize the CNT.                                        |
|           |       | - When TIMx_CTRL1.UPRS = 0, TIMx_CTRL1.UPDIS = 0, and the counter CNT is                         |
|           |       | reinitialized by the trigger event. (See TIMx_SMCTRL Register description)                       |
|           |       | This bit is cleared by software.                                                                 |
|           |       | 0: No update event occurred                                                                      |
|           |       | 1: Update interrupt occurred                                                                     |

# 8.4.7 Event generation registers (TIMx\_EVTGEN)

Offset address: 0x14

Reset values: 0x0000

| 15 |   |      |       |   | 8 | 7   | 6   | 5      | 4     | 3     | 2     | 1     | 0    |
|----|---|------|-------|---|---|-----|-----|--------|-------|-------|-------|-------|------|
|    | 1 | Rese | erved | 1 |   | BGN | TGN | CCUDGN | CC4GN | CC3GN | CC2GN | CC1GN | UDGN |
|    | • |      | •     |   | • | w   | w   | w      | w     | w     | w     | w     | w    |

| Bit field | Name     | Description                                                                                    |
|-----------|----------|------------------------------------------------------------------------------------------------|
| 15: 8     | Reserved | Reserved, the reset value must be maintained                                                   |
| 7         | BGN      | Break generation                                                                               |
|           |          | This bit can generate a brake event when set by software. And at this time TIMx_BKDT.MOEN      |
|           |          | = 0, TIMx_STS.BITF = 1, if the corresponding interrupt is enabled, the corresponding interrupt |
|           |          | will be generated. This bit is automatically cleared by hardware.                              |
|           |          | 0: No action                                                                                   |
|           |          | 1: Generated a break event                                                                     |



| Bit field | Name   | Description                                                                                                |
|-----------|--------|------------------------------------------------------------------------------------------------------------|
| 6         | TGN    | Trigger generation                                                                                         |
|           |        | This bit can generate a trigger event when set by software. And at this time TIMx_STS.TITF =               |
|           |        | 1, if the corresponding interrupt is enabled, the corresponding interrupt will be generated. This          |
|           |        | bit is automatically cleared by hardware.                                                                  |
|           |        | 0: No action                                                                                               |
|           |        | 1: Generated a trigger event                                                                               |
| 5         | CCUDGN | Capture/Compare control update generation                                                                  |
|           |        | This bit is set by software. And if TIMx_CTRL2.CCPCTL = 1 at this time, the CCxEN,                         |
|           |        | CCxNEN and OCxMD bits are allowed to be updated. This bit is automatically cleared by                      |
|           |        | hardware.                                                                                                  |
|           |        | 0: No action                                                                                               |
|           |        | 1: Generated a COM event                                                                                   |
|           |        | Note: This bit is only valid for channels with complementary outputs.                                      |
| 4         | CC4GN  | Capture/Compare 4 generation                                                                               |
|           |        | See TIMx_EVTGEN.CC1GN description.                                                                         |
| 3         | CC3GN  | Capture/Compare 3 generation                                                                               |
|           |        | See TIMx_EVTGEN.CC1GN description.                                                                         |
| 2         | CC2GN  | Capture/Compare 2 generation                                                                               |
|           |        | See TIMx_EVTGEN.CC1GN description.                                                                         |
| 1         | CC1GN  | Capture/Compare 1 generation                                                                               |
|           |        | This bit can generate a capture/compare event when set by software. This bit is automatically              |
|           |        | cleared by hardware.                                                                                       |
|           |        | When the corresponding channel of CC1 is in output mode:                                                   |
|           |        | The TIMx_STS.CC1ITF flag will be pulled high, if the corresponding interrupt and is enabled,               |
|           |        | the corresponding interrupt will be generated.                                                             |
|           |        | When the corresponding channel of CC1 is in input mode:                                                    |
|           |        | TIMx_CCDAT1 will capture the current counter value, and the TIMx_STS.CC1ITF flag will be                   |
|           |        | pulled high, if the corresponding interrupt is enabled, the corresponding interrupt will be                |
|           |        | generated. If The TIMx_STS.CC1ITF is already pulled high, pull TIMx_STS.CC1OCF high.                       |
|           |        | 0: No action                                                                                               |
|           |        | 1: Generated a CC1 capture/compare event                                                                   |
| 0         | UDGN   | Update generation                                                                                          |
|           |        | This bit can generate an update event when set by software. And at this time the counter will be           |
|           |        | reinitialized, the prescaler counter will be cleared, the counter will be cleared in center-aligned or up- |
|           |        | counting mode, but take TIMx_AR in down-counting mode the value of the register. This bit is               |
|           |        | automatically cleared by hardware.                                                                         |
|           |        | 0: No action                                                                                               |
|           |        | 1: Generated an update event                                                                               |

# 8.4.8 Capture/compare mode register 1 (TIMx\_CCMOD1)

Offset address: 0x18



#### Reset value: 0x0000

Channels can be used for input (capture mode) or output (compare mode), and the direction of the channel is defined by the corresponding CCxSEL bit. The other bits of the register act differently in input and output modes. OCx describes the function of a channel in output mode, ICx describes the function of a channel in input mode. Hence, please note that the same bit can have different meanings for output mode and for input mode.

#### Output compare mode:

| 15     | 14 |           | 12 | 11     | 10     | 9     | 8       | 7      | 6 |           | 4 | 3      | 2      | 1     | 0       |
|--------|----|-----------|----|--------|--------|-------|---------|--------|---|-----------|---|--------|--------|-------|---------|
| OC2CEN |    | OC2M[2:0] | ]  | OC2PEN | OC2FEN | CC2SI | EL[1:0] | OC1CEN |   | OC1M[2:0] |   | OC1PEN | OC1FEN | CC1SE | EL[1:0] |
| rw     |    | rw        |    | rw     | rw     | r     | W       | rw     |   | rw        |   | rw     | rw     | r     | W       |

| Bit field | Name        | Description                                                                              |
|-----------|-------------|------------------------------------------------------------------------------------------|
| 15        | OC2CEN      | Output Compare 2 clear enable                                                            |
| 14:12     | OC2MD[2:0]  | Output Compare 2 mode                                                                    |
| 11        | OC2PEN      | Output Compare 2 preload enable                                                          |
| 10        | OC2FEN      | Output Compare 2 fast enable                                                             |
| 9:8       | CC2SEL[1:0] | Capture/compare 2 selection                                                              |
|           |             | These bits are used to select the input/output and input mapping of the channel          |
|           |             | 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 is only active   |
|           |             | when the internal trigger input is selected by TIMx_SMCTRL.TSEL.                         |
|           |             | <i>Note:</i> CC2SEL is writable only when the channel is off ( $TIMx\_CCEN.CC2EN = 0$ ). |
| 7         | OC1CEN      | Output Compare 1 clear enable                                                            |
|           |             | 0: OC1REF is not affected by ETRF input level                                            |
|           |             | 1: OC1REF is cleared immediately when the ETRF input level is detected as high           |
| 6:4       | OC1MD[2:0]  | Output Compare 1 mode                                                                    |
|           |             | These bits are used to manage the output reference signal OC1REF, which determines the   |
|           |             | values of OC1 and OC1N, and is valid at high levels, while the active levels of OC1 and  |
|           |             | OC1N depend on the TIMx_CCEN.CC1P and TIMx_CCEN.CC1NP bits.                              |
|           |             | 000: Frozen. Comparison between TIMx_CCDAT1 register and counter TIMx_CNT has no         |
|           |             | effect on OC1REF signal.                                                                 |
|           |             | 001: Set channel 1 to the active level on match. When TIMx_CCDAT1 = TIMx_CNT,            |
|           |             | OC1REF signal will be forced high.                                                       |
|           |             | 010: Set channel 1 as inactive level on match. When TIMx_CCDAT1 = TIMx_CNT,              |
|           |             | OC1REF signal will be forced low.                                                        |
|           |             | 011: Toggle. When TIMx_CCDAT1 = TIMx_CNT, OC1REF signal will be toggled.                 |
|           |             | 100: Force to inactive level. OC1REF signal is forced low.                               |
|           |             | 101: Force to active level. OC1REF signal is forced high.                                |
|           |             | 110: PWM mode 1 - In up-counting mode, if TIMx_CNT < TIMx_CCDAT1, OC1REF signal          |
|           |             | of channel 1 is high, otherwise it is low. In down-counting mode, if TIMx_CNT >          |
|           |             | TIMx_CCDAT1, OC1REF signal of channel 1 is low, otherwise it is high.                    |



| Bit field | Name        | Description                                                                                   |
|-----------|-------------|-----------------------------------------------------------------------------------------------|
|           |             | 111: PWM mode 2 - In up-counting mode, if TIMx_CNT < TIMx_CCDAT1, OC1REF signal               |
|           |             | of channel 1 is low, otherwise it is high. In down-counting mode, if TIMx_CNT >               |
|           |             | TIMx_CCDAT1, OC1REF signal of channel 1 is high, otherwise it is low.                         |
|           |             | Note 1: In PWM mode 1 or PWM mode 2, the OC1REF level changes only when the                   |
|           |             | comparison result changes or when the output compare mode is switched from frozen mode to     |
|           |             | PWM mode.                                                                                     |
| 3         | OC1PEN      | Output Compare 1 preload enable                                                               |
|           |             | 0: Disable preload function of TIMx_CCDAT1 register. Supports write operations to             |
|           |             | TIMx_CCDAT1 register at any time, and the written value is effective immediately.             |
|           |             | 1: Enable preload function of TIMx_CCDAT1 register. Only read and write operations to         |
|           |             | preload registers. When an update event occurs, the value of TIMx_CCDAT1 is loaded into       |
|           |             | the active register.                                                                          |
|           |             | Note 1: Only when TIMx_CTRL1.ONEPM = 1(In one-pulse mode), PWM mode can be used               |
|           |             | without verifying the preload register, otherwise no other behavior can be predicted.         |
| 2         | OC1FEN      | Output Compare 1 fast enable                                                                  |
|           |             | This bit is used to speed up the response of the CC output to the trigger input event.        |
|           |             | 0: CC1 behaves normally depending on the counter and CCDAT1 values, even if the trigger is    |
|           |             | ON. The minimum delay for activating CC1 output when an edge occurs on the trigger input      |
|           |             | is 5 clock cycles.                                                                            |
|           |             | 1: An active edge of the trigger input acts like a comparison match on CC1 output. Therefore, |
|           |             | OC is set to the comparison level regardless of the comparison result. The delay time for     |
|           |             | sampling the trigger input and activating the CC1 output is reduced to 3 clock cycles.        |
|           |             | OCxFEN only works if the channel is configured in PWM1 or PWM2 mode.                          |
| 1:0       | CC1SEL[1:0] | Capture/compare 1 selection                                                                   |
|           |             | These bits are used to select the input/output and input mapping of the channel               |
|           |             | 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 channels are configured as inputs and IC1 is mapped to TRC. This mode is only         |
|           |             | active when the internal trigger input is selected by TIMx_SMCTRL.TSEL.                       |
|           |             | Note: CC1SEL is writable only when the channel is off ( $TIMx\_CCEN.CC1EN = 0$ ).             |

### Input capture mode:

| 15        |           | 12                      | 11    | 10                      | 9 | 8 | 7         |    | 4 | 3           | 2 | 1           | 0 |
|-----------|-----------|-------------------------|-------|-------------------------|---|---|-----------|----|---|-------------|---|-------------|---|
|           | IC2F[3:0] |                         |       | IC2PSC[1:0] CC2SEL[1:0] |   |   | IC1F[3:0] |    |   | IC1PSC[1:0] |   | CC1SEL[1:0] |   |
|           | rw        |                         |       | rw rw                   |   |   |           | rw | r | w           | r | w           |   |
| Bit field | Name      |                         | Descr | Description             |   |   |           |    |   |             |   |             |   |
| 15.12     | IC2E[2,0] | Insuit Contume 2 Filter |       |                         |   |   |           |    |   |             |   |             |   |

| 15:12 | IC2F[3:0]   | Input Capture 2 Filter    |
|-------|-------------|---------------------------|
| 11:10 | IC2PSC[1:0] | Input Capture 2 Prescaler |
|       |             |                           |



| Name        | Description                                                                                                                                               |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| CC2SEL[1:0] | Capture/Compare 2 selection                                                                                                                               |
|             | These bits are used to select the input/output and input mapping of the channel                                                                           |
|             | 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 is only active when                                                               |
|             | the internal trigger input is selected by TIMx_SMCTRL.TSEL.                                                                                               |
|             | Note: CC2SEL is writable only when the channel is off ( $TIMx\_CCEN.CC2EN = 0$ ).                                                                         |
| IC1F[3:0]   | Input Capture 1 filter                                                                                                                                    |
|             | These bits are used to define sampling frequency of TI1 input and the length of digital filter. The                                                       |
|             | digital filter is an event counter that generates an output transition after N events are recorded.                                                       |
|             | 0000: No filter, sampling at fors frequency                                                                                                               |
|             | $0001$ : fsampling = fck_int, N = 2                                                                                                                       |
|             | 0010: $f_{\text{SAMPLING}} = f_{\text{CK_INT}}$ , N = 4                                                                                                   |
|             | $0011: f_{SAMPLING} = f_{CK_{INT}}, N = 8$                                                                                                                |
|             | 0100: $f_{SAMPLING} = f_{DTS}/2$ , N = 6                                                                                                                  |
|             | 0101: $f_{SAMPLING} = f_{DTS}/2$ , N = 8                                                                                                                  |
|             | 0110: $f_{SAMPLING} = f_{DTS}/4$ , N = 6                                                                                                                  |
|             | 0111: $f_{SAMPLING} = f_{DTS}/4$ , N = 8                                                                                                                  |
|             | 1000: $f_{\text{SAMPLING}} = f_{\text{DTS}}/8$ , N = 6                                                                                                    |
|             | 1001: $f_{\text{SAMPLING}} = f_{\text{DTS}}/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: $f_{SAMPLING} = f_{DTS}/32$ , N = 8                                                                                                                 |
| IC1PSC[1:0] | Input Capture 1 prescaler                                                                                                                                 |
| []          | These bits are used to select the ratio of the prescaler for IC1 (CC1 input).                                                                             |
|             | When TIMx_CCEN.CC1EN = 0, the prescaler will be reset.                                                                                                    |
|             | 00: No prescaler, capture is done each time 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                                                                                                                   |
| CC1SFL[1:0] | Capture/Compare 1 selection                                                                                                                               |
| CCIDEL[1.0] | These bits are used to select the input/output and input mapping of the channel                                                                           |
|             | 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 to TRC. This mode is only active when<br>the internal triager input is selected by TIMx_SMCTPL_TSEL |
|             | the internal trigger input is selected by TIMx_SMCTRL.TSEL.                                                                                               |
| _           | CC2SEL[1:0]                                                                                                                                               |

157 / 319



# 8.4.9 Capture/compare mode register 2 (TIMx\_CCMOD2)

Offset address: 0x1C

Reset value: 0x0000

#### See the description of the CCMOD1 register above

Output comparison mode:

| 15     | 14 |           | 12 | 11     | 10     | 9    | 8       | 7      | 6 |           | 4 | 3      | 2      | 1     | 0       |
|--------|----|-----------|----|--------|--------|------|---------|--------|---|-----------|---|--------|--------|-------|---------|
| OC4CEN |    | OC4MD[2:0 | ]  | OC4PEN | OC4FEN | CC4S | EL[1:0] | OC3CEN |   | OC3MD[2:0 | ] | OC3PEN | OC3FEN | CC3SI | EL[1:0] |
| rw     |    | rw        |    | rw     | rw     | r    | w       | rw     |   | rw        |   | rw     | rw     | r     | w       |

| Bit field | Name        | Description                                                                                 |
|-----------|-------------|---------------------------------------------------------------------------------------------|
| 15        | OC4CEN      | Output compare 4 clear enable                                                               |
| 14:12     | OC4MD[2:0]  | Output compare 4 mode                                                                       |
| 11        | OC4PEN      | Output compare 4 preload enable                                                             |
| 10        | OC4FEN      | Output compare 4 fast enable                                                                |
| 9:8       | CC4SEL[1:0] | Capture/Compare 4 selection                                                                 |
|           |             | These bits are used to select the input/output and input mapping of the channel             |
|           |             | 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 is only active when |
|           |             | the internal trigger input is selected by TIMx_SMCTRL.TSEL.                                 |
|           |             | <i>Note:</i> CC4SEL is writable only when the channel is off ( $TIMx\_CCEN.CC4EN = 0$ ).    |
| 7         | OC3CEN      | Output compare 3 clear enable                                                               |
| 6:4       | OC3MD[2:0]  | Output compare 3 mode                                                                       |
| 3         | OC3PEN      | Output compare 3 preload enable                                                             |
| 2         | OC3FEN      | Output compare 3 fast enable                                                                |
| 1:0       | CC3SEL[1:0] | Capture/Compare 3 selection                                                                 |
|           |             | These bits are used to select the input/output and input mapping of the channel             |
|           |             | 00: CC3 channel is configured as output                                                     |
|           |             | 01: CC3 channel is configured as input, IC3 is mapped to TI3                                |
|           |             | 10: CC3 channel is configured as input, IC3 is mapped on TI4                                |
|           |             | 11: CC3 channel is configured as input, IC3 is mapped to TRC. This mode is only active when |
|           |             | the internal trigger input is selected by TIMx_SMCTRL.TSEL.                                 |
|           |             | <i>Note:</i> CC3SEL is writable only when the channel is off ( $TIMx\_CCEN.CC3EN = 0$ ).    |

#### Input capture mode:





| Bit field | Name        | Description                                                                                 |
|-----------|-------------|---------------------------------------------------------------------------------------------|
| 15:12     | IC4F[3:0]   | Input Capture 4 filter                                                                      |
| 11:10     | IC4PSC[1:0] | Input Capture 4 Prescaler                                                                   |
| 9:8       | CC4SEL[1:0] | Capture/Compare 4 selection                                                                 |
|           |             | These bits are used to select the input/output and input mapping of the channel             |
|           |             | 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 is only active when |
|           |             | the internal trigger input is selected by TIMx_SMCTRL.TSEL.                                 |
|           |             | Note: CC4SEL is writable only when the channel is off $(TIMx\_CCEN.CC4EN = 0)$ .            |
| 7:4       | IC3F[3:0]   | Input Capture 3 filter                                                                      |
| 3:2       | IC3PSC[1:0] | Input Capture 3 Prescaler                                                                   |
| 1:0       | CC3SEL[1:0] | Capture/compare 3 selection                                                                 |
|           |             | These bits are used to select the input/output and input mapping of the channel             |
|           |             | 00: CC3 channel is configured as output                                                     |
|           |             | 01: CC3 channel is configured as input, IC3 is mapped to TI3                                |
|           |             | 10: CC3 channel is configured as input, IC3 is mapped on TI4                                |
|           |             | 11: CC3 channel is configured as input, IC3 is mapped to TRC. This mode is only active when |
|           |             | the internal trigger input is selected by TIMx_SMCTRL.TSEL.                                 |
|           |             | Note: CC3SEL is writable only when the channel is off $(TIMx\_CCEN.CC3EN = 0)$ .            |

# 8.4.10 Capture/compare enable registers (TIMx\_CCEN)

### Offset address: 0x20

Reset value: 0x0000 0000

| 31   |       |      |       |       |        |      |       |       |        |      |       |       | 18     | 17      | 16      |
|------|-------|------|-------|-------|--------|------|-------|-------|--------|------|-------|-------|--------|---------|---------|
|      |       | 1    | 1     | 1     |        | Rese | erved |       |        |      |       |       |        | CC5P    | CC5EN   |
| 15   | 14    | 13   | 12    | 11    | 10     | 9    | 8     | 7     | 6      | 5    | 4     | 3     | 2      | rw<br>1 | rw<br>0 |
| Rese | erved | CC4P | CC4EN | CC3NP | CC3NEN | CC3P | CC3EN | CC2NP | CC2NEN | CC2P | CC2EN | CC1NP | CC1NEN | CC1P    | CC1EN   |
|      |       | rw   | rw    | rw    | rw     | rw   | rw    | rw    | rw     | rw   | rw    | rw    | rw     | rw      | rw      |

| Bit field | Name     | Description                                  |  |  |  |  |  |
|-----------|----------|----------------------------------------------|--|--|--|--|--|
| 31:18     | Reserved | Reserved, the reset value must be maintained |  |  |  |  |  |
| 17        | CC5P     | pture/Compare 5 output polarity              |  |  |  |  |  |
|           |          | See TIMx_CCEN.CC1P description.              |  |  |  |  |  |
| 16        | CC5EN    | Capture/Compare 5 output enable              |  |  |  |  |  |
|           |          | See TIMx_CCEN.CC1EN description.             |  |  |  |  |  |
| 15:14     | Reserved | Reserved, the reset value must be maintained |  |  |  |  |  |
| 13        | CC4P     | Capture/Compare 4 output polarity            |  |  |  |  |  |
|           |          |                                              |  |  |  |  |  |



| Bit field | Name   | Description                                                                                              |
|-----------|--------|----------------------------------------------------------------------------------------------------------|
|           |        | See TIMx_CCEN.CC1P description.                                                                          |
|           |        |                                                                                                          |
| 12        | CC4EN  | Capture/Compare 4 output enable                                                                          |
|           |        | See TIMx_CCEN.CC1EN description.                                                                         |
| 11        | CC3NP  | Capture/Compare 3 Complementary output polarity                                                          |
|           |        | See TIMx_CCEN.CC1NP description.                                                                         |
| 10        | CC3NEN | Capture/Compare 3 complementary output enable                                                            |
|           |        | See TIMx_CCEN.CC1NEN description.                                                                        |
| 9         | CC3P   | Capture/Compare 3 output polarity                                                                        |
|           |        | See TIMx_CCEN.CC1P description.                                                                          |
| 8         | CC3EN  | Capture/Compare 3 output enable                                                                          |
|           |        | See TIMx_CCEN.CC1EN description.                                                                         |
| 7         | CC2NP  | Capture/Compare 2 complementary output polarity                                                          |
|           |        | See TIMx_CCEN.CC1NP description.                                                                         |
| 6         | CC2NEN | Capture/Compare 2 complementary output enable                                                            |
|           |        | See TIMx_CCEN.CC1NEN description.                                                                        |
| 5         | CC2P   | Capture/Compare 2 output polarity                                                                        |
|           |        | See TIMx_CCEN.CC1P description.                                                                          |
| 4         | CC2EN  | Capture/Compare 2 output enable                                                                          |
|           |        | See TIMx_CCEN.CC1EN description.                                                                         |
| 3         | CC1NP  | Capture/Compare 1 complementary output polarity                                                          |
|           |        | 0: OC1N active high                                                                                      |
|           |        | 1: OC1N active low                                                                                       |
| 2         | CC1NEN | Capture/Compare 1 complementary output enable                                                            |
|           |        | 0: Disable - Disable output OC1N signal. The level of OC1N depends on the value of these bits            |
|           |        | TIMx_BKDT.MOEN, TIMx_BKDT.OSSI, TIMx_BKDT.OSSR, TIMx_CTRL2.OI1,                                          |
|           |        | TIMx_CTRL2.0I1N and TIMx_CCEN.CC1EN.                                                                     |
|           |        | 1: Enable - Enable output OC1N signal. The level of OC1N depends on the value of these bits              |
|           |        | TIMx_BKDT.MOEN, TIMx_BKDT.OSSI, TIMx_BKDT.OSSR, TIMx_CTRL2.OI1,                                          |
|           |        | TIMx_CTRL2.0I1N and TIMx_CCEN.CC1EN.                                                                     |
| 1         | CC1P   | Capture/Compare 1 output polarity                                                                        |
|           |        | When the corresponding channel of CC1 is in output mode:                                                 |
|           |        | 0: OC1 active high                                                                                       |
|           |        | 1: OC1 active low                                                                                        |
|           |        | When the corresponding channel of CC1 is in input mode:                                                  |
|           |        | At this time, this bit is used to select whether IC1 or the inverse signal of IC1 is used as the trigger |
|           |        | or capture signal.                                                                                       |
|           |        | 0: non-inverted: Capture action occurs when IC1 generates a rising edge. When used as external           |
|           |        | trigger, IC1 is non-inverted.                                                                            |
|           |        | 1: inverted: Capture action occurs when IC1 generates a falling edge. When used as external              |
|           |        | trigger, IC1 is inverted.                                                                                |
|           |        | Note: If $TIMx\_BKDT.LCKCFG = 3$ or 2, these bits cannot be modified.                                    |

160 / 319



| Bit field | Name  | Description                                                                                 |
|-----------|-------|---------------------------------------------------------------------------------------------|
| 0         | CC1EN | Capture/Compare 1 output enable                                                             |
|           |       | When the corresponding channel of CC1 is in output mode:                                    |
|           |       | 0: Disable - Disable output OC1 signal. The level of OC1 depends on the value of these bits |
|           |       | TIMx_BKDT.MOEN, TIMx_BKDT.OSSI, TIMx_BKDT.OSSR, TIMx_CTRL2.0I1,                             |
|           |       | TIMx_CTRL2.011N and TIMx_CCEN.CC1NEN.                                                       |
|           |       | 1: Enable - Enable output OC1 signal. The level of OC1N depends on the value of these bits  |
|           |       | TIMx_BKDT.MOEN, TIMx_BKDT.OSSI, TIMx_BKDT.OSSR, TIMx_CTRL2.011,                             |
|           |       | TIMx_CTRL2.011N and TIMx_CCEN.CC1NEN.                                                       |
|           |       | When the corresponding channel of CC1 is in input mode:                                     |
|           |       | At this time, this bit is used to disable/enable the capture function.                      |
|           |       | 0: Disable capture                                                                          |
|           |       | 1: Enable capture                                                                           |

#### Table 8-3 Output control bits of complementary OCx and OCxN channels with break function

| Control | bits  |      |                                                                                 |                                                                        | Output state <sup>1)</sup>                                             |                                                                 |  |  |  |  |  |
|---------|-------|------|---------------------------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------|-----------------------------------------------------------------|--|--|--|--|--|
| MOEN    | OSSI  | OSSR | CCxEN                                                                           | CCxNEN                                                                 | OCx Output state                                                       | OCxN Output state                                               |  |  |  |  |  |
|         |       | 0    | 0                                                                               | 0 (timer)                                                              |                                                                        | Output disabled (not driven by timer)<br>OCxN=0,OCxN_EN=0       |  |  |  |  |  |
|         |       | 0    | 0                                                                               | 1                                                                      | Output disabled (not driven by<br>timer)<br>OCx=0,OCx_EN=0             | OCxREF + polarity,<br>OCxN= OCxREF xor CCxNP,OCxN_EN=1          |  |  |  |  |  |
|         |       | 0    | 1                                                                               | 0                                                                      | OCxREF + polarity,<br>OCx= OCxREF xor CCxP,OCx_EN=1                    | Output disabled (not driven by timer)<br>OCxN=0,OCxN_EN=0       |  |  |  |  |  |
|         | 0 1 1 |      |                                                                                 | 1                                                                      | OCxREF + polarity + dead-<br>time,OCx_EN=1                             | Complementary to OCxREF + polarity +<br>dead-time,OCxN_EN=1     |  |  |  |  |  |
| 1       | х     | 1    | 0                                                                               | 0                                                                      | Output disabled (not driven by<br>timer)<br>OCx=CCxP,OCx_EN=0          | Output disabled (not driven by timer)<br>OCxN=CCxNP,OCxN_EN=0   |  |  |  |  |  |
|         |       | 1    | 0                                                                               | 1                                                                      | Off-state (Output enabled with inactive<br>state)<br>OCx=CCxP,OCx_EN=1 | OCxREF + polarity,<br>OCxN= OCxREF xor CCxNP,OCxN_EN=1          |  |  |  |  |  |
|         |       | 1    | $\begin{array}{c c} OCxREF + polarity, \\ 0 OCx = OCxREF xor CCxP. \end{array}$ | Off-state (Output enabled with inactive state)<br>OCxN=CCxNP,OCxN_EN=1 |                                                                        |                                                                 |  |  |  |  |  |
|         |       | 1    | 1                                                                               | 1                                                                      | OCxREF + polarity + dead-time,<br>OCx_EN=1                             | Complementary to OCxREF + polarity +<br>dead-time,<br>OCxN_EN=1 |  |  |  |  |  |
| 0       | 0     | Х    | 0                                                                               | 0                                                                      | Output disabled (not driven by timer)                                  |                                                                 |  |  |  |  |  |
|         | 0     |      | 0                                                                               | 1                                                                      | Asynchronously: OCx=CCxP, OCx_B                                        | EN=0, OCxN=CCxNP,OCxN_EN=0;                                     |  |  |  |  |  |



| Control | bits |      |       |        | Output state <sup>1)</sup>                                                  |                            |  |  |  |  |  |  |
|---------|------|------|-------|--------|-----------------------------------------------------------------------------|----------------------------|--|--|--|--|--|--|
| MOEN    | OSSI | OSSR | CCxEN | CCxNEN | OCx Output state OCxN Output state                                          |                            |  |  |  |  |  |  |
|         | 0    |      | 1     | 0      | Then if the clock is present: OCx=OIx and OCxN=OIxN after a dead-time, when |                            |  |  |  |  |  |  |
|         | 0    |      | 1     | 1      | $(CCxP \land OIx) \land (CCxNP \land OIxN)! = 0.$                           |                            |  |  |  |  |  |  |
|         | 1    |      | 0     | 0      | Off-state (Output enabled with inactive s                                   | state)                     |  |  |  |  |  |  |
|         | 1    |      | 0     | 1      | Asynchronously: OCx=CCxP, OCx_E                                             | N=1, OCxN=CCxNP,OCxN_EN=1; |  |  |  |  |  |  |
|         | 1    |      | 1     | 0      | Then if the clock is present: OCx=OIx and OCxN=OIxN after a dead-time, when |                            |  |  |  |  |  |  |
|         | 1    |      | 1     | 1      | $(CCxP \land OIx) \land (CCxNP \land OIxN)! = 0.$                           |                            |  |  |  |  |  |  |

1. If both outputs of a channel are not used (CCxEN = CCxNEN = 0), OIx, OIxN, CCxP and CCxNP must all be cleared.

*Note: The status of external I/O pins connected to complementary OCx and OCxN channels depends on the OCx and OCxN channel states and GPIO and AFIO registers.* 

## 8.4.11 Counters (TIMx\_CNT)

Offset address: 0x24

Reset value: 0x0000

| 15 |      |   |       |           |   |      |       | 0    |
|----|------|---|-------|-----------|---|------|-------|------|
|    |      | 1 |       |           |   |      |       |      |
|    |      |   |       | CNT[15:0] |   |      |       |      |
|    | <br> |   | <br>1 | <br>      | - | <br> | <br>1 | <br> |
|    |      |   |       | rw        |   |      |       |      |

| Bit field | Name      | Description   |
|-----------|-----------|---------------|
| 15:0      | CNT[15:0] | Counter value |

## 8.4.12 Prescaler (TIMx\_PSC)

Offset address: 0x28

Reset value: 0x0000

| 15 |   |   |      |      |           |      |      |      | 0 |
|----|---|---|------|------|-----------|------|------|------|---|
|    | 1 | 1 | 1    | 1    |           |      |      | 1    |   |
|    |   |   |      |      | PSC[15:0] |      |      |      |   |
| 1  |   | 1 | <br> | <br> |           | <br> | <br> | <br> |   |
|    |   |   |      |      | rw        |      |      |      |   |

| PSC/ (PSC [15:0] +1).                                              |
|--------------------------------------------------------------------|
| ccurs, the PSC value is loaded into the active prescaler register. |
|                                                                    |

## 8.4.13 Auto-reload register (TIMx\_AR)

Offset address: 0x2C

Reset values: 0xFFFF



| 15 |          |   |   |   |   |   |  |  |   |   |       |       | 0 |
|----|----------|---|---|---|---|---|--|--|---|---|-------|-------|---|
|    | 1        | 1 | 1 | 1 | 1 | 1 |  |  | 1 | 1 | 1     | 1     |   |
|    | AR[15:0] |   |   |   |   |   |  |  |   |   |       |       |   |
|    | I        | 1 | I | 1 | I | L |  |  | l | I | <br>I | <br>1 |   |
|    |          |   |   |   |   |   |  |  |   |   |       |       |   |

rw

| Bit field | Name     | Description                                                                           |
|-----------|----------|---------------------------------------------------------------------------------------|
| 15:0      | AR[15:0] | Auto-reload value                                                                     |
|           |          | These bits define the value that will be loaded into the actual auto-reload register. |
|           |          | See Section 8.3.1 for more details.                                                   |
|           |          | When the TIMx_AR.AR [15:0] value is null, the counter does not work.                  |

# 8.4.14 Repeat count registers (TIMx\_REPCNT)

Offset address: 0x30

Reset value: 0x0000

| 15 |          | 8     | 8 7 |             |     | 0   |  |  |  |
|----|----------|-------|-----|-------------|-----|-----|--|--|--|
| 1  |          | I I I |     | 1 1         | 1 1 | 1 1 |  |  |  |
|    | Reserved |       |     | REPCNT[7:0] |     |     |  |  |  |
| 1  |          | I I I |     | 1 1         |     | 1 1 |  |  |  |
|    |          |       |     |             | rw  |     |  |  |  |

| Bit field | Name        | Description                                                                                        |
|-----------|-------------|----------------------------------------------------------------------------------------------------|
| 15:8      | Reserved    | Reserved, the reset value must be maintained                                                       |
| 7:0       | REPCNT[7:0] | Repetition counter value                                                                           |
|           |             | Repetition counter is used to generate the update event or update the timer registers only after a |
|           |             | given number $(N+1)$ cycles of the counter, where N is the value of TIMx_REPCNT.REPCNT .           |
|           |             | The repetition counter is decremented at each counter overflow in up-counting mode, at each        |
|           |             | counter underflow in down-counting mode or at each counter overflow and at each counter            |
|           |             | underflow in center-aligned mode. Setting the TIMx_EVTGEN.UDGN bit will reload the content         |
|           |             | of TIMx_REPCNT.REPCNT and generate an update event.                                                |
|           |             |                                                                                                    |

# 8.4.15 Capture/compare register 1 (TIMx\_CCDAT1)

Offset address: 0x34

Reset value: 0x0000

| 15 |   |   |   |   |   |   |       |          |   |   |   |   |   | 0 |
|----|---|---|---|---|---|---|-------|----------|---|---|---|---|---|---|
|    | 1 | 1 | 1 | 1 | 1 | 1 | 1     | 1        | 1 | 1 | 1 | 1 | 1 |   |
|    |   |   |   |   |   |   | CCDAT | [1[15:0] |   |   |   |   |   |   |
|    | 1 | 1 | - | 1 | 1 |   | 1     |          | 1 |   | 1 | 1 |   |   |
|    |   |   |   |   |   |   | rv    | v/r      |   |   |   |   |   |   |

| Bit field | Name         | Description                                                                            |
|-----------|--------------|----------------------------------------------------------------------------------------|
| 15:0      | CCDAT1[15:0] | Capture/Compare 1 value                                                                |
|           |              | CC1 channel is configured as output:                                                   |
|           |              | CCDAT1 contains the value to be compared to the counter TIMx_CNT, signaling on the OC1 |
|           |              | output.                                                                                |



| Bit field | Name | Description                                                                                           |
|-----------|------|-------------------------------------------------------------------------------------------------------|
|           |      | If the preload feature is not selected in TIMx_CCMOD1.OC1PEN bit, the written value is                |
|           |      | immediately transferred to the active register. Otherwise, this preloaded value is transferred to the |
|           |      | active register only when an update event occurs.                                                     |
|           |      | CC1 channel is configured as input:                                                                   |
|           |      | CCDAT1 contains the counter value transferred by the last input capture 1 event (IC1).                |
|           |      | When configured as input mode, register CCDAT1 and CCDDAT1 are only readable.                         |
|           |      | When configured as output mode, register CCDAT1 and CCDDAT1 are readable and writable.                |

# 8.4.16 Capture/compare register 2 (TIMx\_CCDAT2)

Offset address: 0x38

Reset value: 0x0000

| 15 |      |   |  |       |          |  |   |   |  | 0 |
|----|------|---|--|-------|----------|--|---|---|--|---|
|    | 1    | 1 |  |       | 1        |  | 1 | 1 |  | 1 |
|    |      |   |  | CCDAT | [2[15:0] |  |   |   |  |   |
|    | <br> |   |  |       | l        |  |   | 1 |  |   |
|    |      |   |  |       |          |  |   |   |  |   |

rw/r

| Bit field | Name         | Description                                                                                           |
|-----------|--------------|-------------------------------------------------------------------------------------------------------|
| 15:0      | CCDAT2[15:0] | Capture/Compare 2 values                                                                              |
|           |              | CC2 channel is configured as output:                                                                  |
|           |              | CCDAT2 contains the value to be compared to the counter TIMx_CNT, signaling on the OC2                |
|           |              | output.                                                                                               |
|           |              | If the preload feature is not selected in TIMx_CCMOD1.OC2PEN bit, the written value is                |
|           |              | immediately transferred to the active register. Otherwise, this preloaded value is transferred to the |
|           |              | active register only when an update event occurs.                                                     |
|           |              | CC2 channel is configured as input:                                                                   |
|           |              | CCDAT2 contains the counter value transferred by the last input capture 2 event (IC2).                |
|           |              | When configured as input mode, register CCDAT2 and CCDDAT2 are only readable.                         |
|           |              | When configured as output mode, register CCDAT2 and CCDDAT2 are readable and writable.                |

# 8.4.17 Capture/compare register 3 (TIMx\_CCDAT3)

Offset address: 0x3C

Reset value: 0x0000



rw/r



| Bit field | Name         | Description                                                                                       |
|-----------|--------------|---------------------------------------------------------------------------------------------------|
| 15:0      | CCDAT3[15:0] | Capture/Compare 3 value                                                                           |
|           |              | CC3 channel is configured as output:                                                              |
|           |              | CCDAT3 contains the value to be compared to the counter TIMx_CNT, signaling on the OC3            |
|           |              | output.                                                                                           |
|           |              | If the preload feature is not selected in TIMx_CCMOD2.OC3PEN bit, the written value is            |
|           |              | immediately transferred to the active register. Otherwise, this preloaded value is transferred to |
|           |              | the active register only when an update event occurs.                                             |
|           |              | CC3 channel is configured as input:                                                               |
|           |              | CCDAT3 contains the counter value transferred by the last input capture 3 event (IC3).            |
|           |              | When configured as input mode, register CCDAT3 and CCDDAT3 are only readable.                     |
|           |              | When configured as output mode, register CCDAT3 and CCDDAT3 are readable and writable.            |

## 8.4.18 Capture/compare register 4 (TIMx\_CCDAT4)

### Offset address: 0x40

Reset value: 0x0000

| 15 |     |   |   |   |       |          |           |   |   |   | 0 |
|----|-----|---|---|---|-------|----------|-----------|---|---|---|---|
| 1  | 1 1 | 1 | 1 | 1 | 1     | 1        | · · · · · | 1 | 1 | 1 |   |
|    |     |   |   |   | CCDAT | [4[15:0] |           |   |   |   |   |
|    | 1 1 | 1 |   | 1 | L     | I        |           | I | L | 1 |   |
|    |     |   |   |   |       | ,        |           |   |   |   |   |

| Bit field | Name         | Description                                                                                       |
|-----------|--------------|---------------------------------------------------------------------------------------------------|
| 15:0      | CCDAT4[15:0] | Capture/Compare 4 value                                                                           |
|           |              | CC4 channel is configured as output:                                                              |
|           |              | CCDAT4 contains the value to be compared to the counter TIMx_CNT, signaling on the OC4            |
|           |              | output.                                                                                           |
|           |              | If the preload feature is not selected in TIMx_CCMOD2.OC4PEN bit, the written value is            |
|           |              | immediately transferred to the active register. Otherwise, this preloaded value is transferred to |
|           |              | the active register only when an update event occurs.                                             |
|           |              | CC4 channel is configured as input:                                                               |
|           |              | CCDAT4 contains the counter value transferred by the last input capture 4 event (IC4).            |
|           |              | When configured as input mode, register CCDAT4 and CCDDAT4 are only readable.                     |
|           |              | When configured as output mode, register CCDAT4 and CCDDAT4 are readable and writable.            |

# 8.4.19 Break and Dead-time registers (TIMx\_BKDT)

Offset address: 0x44

Reset value: 0x0000



Note: AOEN, BKP, BKEN, OSSI, OSSR, and DTGN [7:0] bits can all be write protected depending on the LOCK

165 / 319

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



### configuration, and it is necessary to configure all of them on the first write to the TIMx\_BKDT register.

| Bit field | Name        | Description                                                                                      |  |  |  |  |  |
|-----------|-------------|--------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 15 MOEN   |             | Main Output enable                                                                               |  |  |  |  |  |
|           |             | This bit can be set by software or hardware depending on the TIMx_BKDT.AOEN bit, and is          |  |  |  |  |  |
|           |             | asynchronously cleared to '0' by hardware once the brake input is active. It is only valid for   |  |  |  |  |  |
|           |             | channels configured as outputs.                                                                  |  |  |  |  |  |
|           |             | 0: OC and OCN outputs are disabled or forced to idle state.                                      |  |  |  |  |  |
|           |             | 1: OC and OCN outputs are enabled if TIMx_CCEN.CCxEN or TIMx_CCEN.CCxNEN bits are                |  |  |  |  |  |
|           |             | set. For more details, see Section 8.4.10 Capture/Compare enable registers (TIMx_CCEN).          |  |  |  |  |  |
| 14        | AOEN        | Automatic output enable                                                                          |  |  |  |  |  |
|           |             | 0: Only software can set TIMx_BKDT.MOEN;                                                         |  |  |  |  |  |
|           |             | 1: Software sets TIMx_BKDT.MOEN; or if the break input is not active, when the next update       |  |  |  |  |  |
|           |             | event occurs, hardware automatically sets TIMx_BKDT.MOEN.                                        |  |  |  |  |  |
| 13        | ВКР         | Break input polarity                                                                             |  |  |  |  |  |
|           |             | 0: Low level of the brake input is valid                                                         |  |  |  |  |  |
|           |             | 1: High level of the brake input is valid                                                        |  |  |  |  |  |
|           |             | Note: Any write to this bit requires an APB clock delay to take effect.                          |  |  |  |  |  |
| 12        | BKEN        | Break enable                                                                                     |  |  |  |  |  |
|           |             | 0: Disable brake input (BRK and CCS clock failure events)                                        |  |  |  |  |  |
|           |             | 1: Enable brake input (BRK and CCS clock failure events)                                         |  |  |  |  |  |
|           |             | Note: Any write to this bit requires an APB clock delay to take effect.                          |  |  |  |  |  |
| 11        | OSSR        | Off-state Selection for Run Mode                                                                 |  |  |  |  |  |
|           |             | This bit is used when TIMx_BKDT.MOEN=1 and the channel is a complementary output.                |  |  |  |  |  |
|           |             | The OSSR bit does not exist in timer without complementary outputs.                              |  |  |  |  |  |
|           |             | 0: When inactive, $OCx/OCxN$ outputs are disabled ( $OCx/OCxN$ enable output signal = 0)         |  |  |  |  |  |
|           |             | 1: When inactive, OCx/OCxN outputs are enabled with their inactive level as soon as CCxEN = 1    |  |  |  |  |  |
|           |             | or $CCxNEN = 1$ . Then, $OCx/OCxN$ enable output signal = 1                                      |  |  |  |  |  |
|           |             | For more details, See Section 8.4.10, capture/compare enablement registers (TIMx_CCEN).          |  |  |  |  |  |
| 10        | OSSI        | Off-state Selection for Idle Mode                                                                |  |  |  |  |  |
|           |             | This bit is used when TIMx_BKDT.MOEN=0 and the channels configured as outputs.                   |  |  |  |  |  |
|           |             | 0: When inactive, $OCx/OCxN$ outputs are disabled ( $OCx/OCxN$ enable output signal = 0)         |  |  |  |  |  |
|           |             | 1: When inactive, $OCx/OCxN$ outputs are enabled with their idle level as soon as $CCxEN = 1$ or |  |  |  |  |  |
|           |             | CCxNEN = 1. Then, $OCx/OCxN$ enable output signal = 1                                            |  |  |  |  |  |
|           |             | For more details, See Section 8.4.10, capture/compare enablement registers (TIMx_CCEN).          |  |  |  |  |  |
| 9:8       | LCKCFG[1:0] | Lock Configuration                                                                               |  |  |  |  |  |
|           |             | These bits offer a write protection against software errors.                                     |  |  |  |  |  |
|           |             | 00:                                                                                              |  |  |  |  |  |
|           |             | – No write protected.                                                                            |  |  |  |  |  |
|           |             | 01:                                                                                              |  |  |  |  |  |
|           |             | – LOCK Level 1                                                                                   |  |  |  |  |  |
|           |             | TIMx_BKDT.DTGN, TIMx_BKDT.BKEN, TIMx_BKDT.BKP, TIMx_BKDT.AOEN,                                   |  |  |  |  |  |



| Bit field | Name       | Description                                                                                |
|-----------|------------|--------------------------------------------------------------------------------------------|
|           |            | TIMx_CTRL2.OIx, TIMx_CTRL2.OIxN bits enable write protection.                              |
|           |            | 10:                                                                                        |
|           |            | – LOCK Level 2                                                                             |
|           |            | Except for register write protection in LOCK Level 1 mode, TIMx_CCEN.CCxP and              |
|           |            | TIMx_CCEN.CCxNP (If the corresponding channel is configured in output mode),               |
|           |            | TIMx_BKDT.OSSR and TIMx_BKDT.OSSI bits also enable write protection.                       |
|           |            | 11:                                                                                        |
|           |            | – LOCK Level 3                                                                             |
|           |            | Except for register write protection in LOCK Level 2, TIMx_CCMODx.OCxMD and                |
|           |            | TIMx_CCMODx.OCxPEN bits (If the corresponding channel is configured in output mode) also   |
|           |            | enable write protection.                                                                   |
|           |            | Note: After the system reset, the LCKCFG bit can only be written once. Once written to the |
|           |            | TIMx_BKDT register, LCKCFG will be protected until the next reset.                         |
| 7:0       | DTGN [7:0] | Dead-time Generator                                                                        |
|           |            | These bits define the dead-time duration between inserted complementary outputs. The       |
|           |            | relationship between the DTGN value and the dead time is as follows::                      |
|           |            | DTGN[7:5] = 0xx:                                                                           |
|           |            | dead time = DTGN[7:0] $\times$ (t <sub>DTS</sub> )                                         |
|           |            | DTGN[7:5] = 10x:                                                                           |
|           |            | dead time =(64+DTGN[5:0]) $\times$ (2 $\times$ t <sub>DTS</sub> )                          |
|           |            | DTGN[7:5]=110:                                                                             |
|           |            | dead time = $(32+DTGN[4:0]) \times (8 \times t_{DTS})$                                     |
|           |            | DTGN [then] = 111:                                                                         |
|           |            | dead time = $(32 + \text{DTGN } [4:0]) \times (16 \times t_{\text{DTS}})$                  |
|           |            | t <sub>DTS</sub> value see TIMx_CTRL1.CLKD [1:0].                                          |

# 8.4.20 Capture/compare mode registers 3(TIMx\_CCMOD3)

Offset address: 0x54

Reset value: 0x0000

| 15 |   |      |       |   |   | 8 | 7      | 6 |            | 4 | 3      | 2      | 1    | 0     |
|----|---|------|-------|---|---|---|--------|---|------------|---|--------|--------|------|-------|
|    | 1 | Reso | erved | 1 | 1 | 1 | OC5CEN | ( | DC5MD[2:0] |   | OC5PEN | OC5FEN | Rese | erved |
|    |   |      | •     |   |   |   | rw     |   | rw         |   | rw     | rw     |      |       |

| Bit field | Name       | Description                                  |
|-----------|------------|----------------------------------------------|
| 15:8      | Reserved   | Reserved, the reset value must be maintained |
| 7         | OC5CEN     | Output compare 5 clear enable                |
| 6:4       | OC5MD[2:0] | Output compare 5 mode                        |
| 3         | OC5PEN     | Output compare 5 Preload enable              |
| 2         | OC5FEN     | Output compare 5 fast enable                 |



| Bit field | Name     | Description                                  |
|-----------|----------|----------------------------------------------|
| 1: 0      | Reserved | Reserved, the reset value must be maintained |

## 8.4.21 Capture/compare register 5 (TIMx\_CCDAT5)

Offset address: 0x58

Reset value: 0x0000

| 15 |   |   |   |      |      |          |     |   |   |   |   | 0 |
|----|---|---|---|------|------|----------|-----|---|---|---|---|---|
|    | 1 | 1 | 1 | 1    |      | 1        | 1 1 | 1 | 1 | 1 | 1 |   |
|    |   |   |   |      | CCDA | T5[15:0] |     |   |   |   |   |   |
|    |   |   |   | <br> | 1    | 1        | I I |   |   |   | 1 |   |
|    |   |   |   |      |      | w        |     |   |   |   |   |   |

| Bit field | Name         | Description                                                                                       |
|-----------|--------------|---------------------------------------------------------------------------------------------------|
| 15:0      | CCDAT5[15:0] | Capture/Compare 5 value                                                                           |
|           |              | CC5 channel can only configured as output:                                                        |
|           |              | CCDAT5 contains the value to be compared to the counter TIMx_CNT, signaling on the OC5            |
|           |              | output.                                                                                           |
|           |              | If the preload feature is not selected in TIMx_CCMOD3.OC5PEN bit, the written value is            |
|           |              | immediately transferred to the active register. Otherwise, this preloaded value is transferred to |
|           |              | the active register only when an update event occurs.                                             |
|           |              | TIM1_CC5 and TIM8_CC5 is used for comparator blanking.                                            |



# 9 General-purpose timers (TIM3)

## 9.1 General-purpose timers introduction

The general-purpose timers (TIM3) is mainly used in the following occasions: counting the input signal, measuring the pulse width of the input signal and generating the output waveform, etc.

## 9.2 Main features of General-purpose timers

- 16-bit auto-reload counters. (It can realize up-counting, down-counting, up/down counting)
- 16-bit programmable prescaler. (The frequency division factor can be configured with any value between 1 and 65536)
- TIM3 up to 2 channels
- Channel's working modes: PWM output, ouput compare, one-pulse mode output, input capture
- The events that generate the interrupt are as follows:
  - Update event
  - Trigger event
  - Input capture
  - Output compare
- Timer can be controlled by external signal
- Timers are linked internally for timer synchronization or chaining
- Supports capturing internal comparator output signals



#### Figure 9-1 Block diagram of TIMx (x=3)



The capture channel 1 input can come from IOM or comparator output

# 9.3 General-purpose timer description

## 9.3.1 Time-base unit

The time-base unit mainly includes: prescaler, counter and auto-reload. When the time base unit is working, the software can read and write the corresponding registers (TIMx\_PSC, TIMx\_CNT and TIMx\_AR) at any time.

Depending on the setting of the auto-reload preload enable bit (TIMx\_CTRL1.ARPEN), the value of the preload register is transferred to the shadow register immediately or at each update event UEV. An update event is generated when the counter reaches the overflow/underflow condition and it can be generated by software when TIMx\_CTRL1.UPDIS=0. The counter CK\_CNT is valid only when the TIMx\_CTRL1.CNTEN bit is set. The counter starts counting one clock cycle after the TIMx\_CTRL1.CNTEN bit is set.

### 9.3.1.1 Prescaler description

The TIMx\_PSC register consists of a 16-bit counter that can be used to divide the counter clock frequency by any factor between 1 and 65536. It can be changed on the fly as it is buffered. The prescaler value is only taken into account at the next update event.





#### Figure 9-2 Counter timing diagram with prescaler division change from 1 to 4

## 9.3.2 **Counter mode**

#### 9.3.2.1 Up-counting mode

In up-counting mode, the counter will count from 0 to the value of the register TIMx\_AR, then it resets to 0. And a counter overflow event is generated.

If the TIMx\_CTRL1.UPRS bit (select update request) and the TIMx\_EVTGEN.UDGN bit are set, an update event (UEV) will generate And TIMx\_STS.UDITF will not be set by hardware, therefore, no update interrupts are generated. This setting is used in scenarios where you want to clear the counter but do not want to generate an update interrupt.

Depending on the update request source is configured in TIMx\_CTRL1.UPRS, When an update event occurs, all registers are updated and the TIMx\_STS.UDITF is set:

- Update auto-reload shadow registers with preload value(TIMx\_AR), when TIMx\_CTRL1.ARPEN = 1.
- The prescaler shadow register is reloaded with the preload value(TIMx\_PSC).

To avoid updating the shadow registers when new values are written to the preload registers, you can disable the update by setting TIMx\_CTRL1.UPDIS=1.

When an update event occurs, the counter will still be cleared and the prescaler counter will also be set to 0 (but the prescaler value will remain unchanged).



The figure below shows some examples of the counter behavior and the update flags for different division factors in the up-counting mode.

| Internal clock |                              |                                    |
|----------------|------------------------------|------------------------------------|
| divided by 2   | CNTEN                        |                                    |
|                | CK_PSC                       |                                    |
|                | Timer clock = CK_CNT         |                                    |
|                | Counter register             | 0034 0035 0036 0000 0001 0002 0003 |
|                | Counter overflow             |                                    |
|                | Update interrupt flag(UDITF) |                                    |
|                | Update event(UEV)            |                                    |
|                |                              |                                    |
| Internal clock |                              |                                    |
| divided by N   | CK_PSC                       |                                    |
|                | Timer clock = CK_CNT         |                                    |
|                | Counter register             | 1F 20 00                           |
|                | Counter overflow             |                                    |
|                | Update interrupt flag(UDITF) |                                    |
|                | Update event(UEV)            |                                    |
|                |                              |                                    |

#### Figure 9-3 Timing diagram of up-counting. The internal clock divider factor = 2/N



| ARPEN = 0 <sub>CNTEN</sub>            |                                                          |  |  |  |  |  |  |  |
|---------------------------------------|----------------------------------------------------------|--|--|--|--|--|--|--|
| CK_PSC                                |                                                          |  |  |  |  |  |  |  |
| Timer clock = CK_CNT                  |                                                          |  |  |  |  |  |  |  |
| Counter register                      | 31 \32 \33 \34 \35 \36 \00 \01 \02 \03 \04 \05 \06 \07 \ |  |  |  |  |  |  |  |
| Counter overflow                      |                                                          |  |  |  |  |  |  |  |
| Update event (UEV)                    |                                                          |  |  |  |  |  |  |  |
| Update interrupt flag(UDITF)          |                                                          |  |  |  |  |  |  |  |
| Auto-reload preload register          | FF 36                                                    |  |  |  |  |  |  |  |
| Write a new                           | Change AR value<br>value in TIMx_AR                      |  |  |  |  |  |  |  |
| ARPEN = 1                             |                                                          |  |  |  |  |  |  |  |
| CNTEN                                 |                                                          |  |  |  |  |  |  |  |
| CK_PSC                                |                                                          |  |  |  |  |  |  |  |
| Timer clock = CK_CNT                  |                                                          |  |  |  |  |  |  |  |
| Counter register                      | F0 \F1 \F2 \F3 \F4 \F5 \00 \01 \02 \03 \04 \05 \06 \07 \ |  |  |  |  |  |  |  |
| Counter overflow                      |                                                          |  |  |  |  |  |  |  |
| Update event (UEV)                    |                                                          |  |  |  |  |  |  |  |
| Update interrupt flag(UDITF)          |                                                          |  |  |  |  |  |  |  |
| Auto-reload preload register          | F5 36                                                    |  |  |  |  |  |  |  |
| Write a new                           | Write a new value in TIMx_AR                             |  |  |  |  |  |  |  |
| -<br>Auto-reload shadow register<br>- | F5 36                                                    |  |  |  |  |  |  |  |

#### Figure 9-4 Timing diagram of the up-counting, update event when ARPEN=0/1

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



### 9.3.2.2 **Down-counting mode**

In down-counting mode, the counter will decrement from the value of the register TIMx\_AR to 0, then restart from the auto-reload value and generate a counter underflow event.

The process of configuring update events and updating registers in down-counting mode is the same as in up-counting mode, see 9.3.2.1.

The figure below shows some examples of the counter behavior and the update flags for different division factors in the down-counting mode.



Figure 9-5 Timing diagram of the down-counting, internal clock divided factor = 2/N

### 9.3.2.3 Center-aligned mode

In center-aligned mode, the counter increments from 0 to the value  $(TIMx_AR) - 1$ , a counter overflow event is generated. It then counts down from the auto-reload value  $(TIMx_AR)$  to 1 and generates a counter underflow event. Then the counter resets to 0 and starts counting up again.

In this mode, the TIMx\_CTRL1.DIR direction bits have no effect and the count direction is updated and specified by hardware. Center-aligned mode is valid when the TIMx\_CTRL1. CAMSEL bit is not equal to "00".

The update events can be generated each time the counter overflows and each time the counter underflows.

174 / 319



Alternatively, an update event can also be generated by setting the TIMx\_EVTGEN. UDGN bit (either by software or using a slave mode controller). In this case, the counter restarts from 0, as does the prescaler's counter.

Please note: if the update source is a counter overflow, auto-reload update before reloading the counter.

#### Figure 9-6 Timing diagram of the Center-aligned, internal clock divided factor =2/N

| Internal clock<br>divided by 2 | CK_PSC<br>CNTEN                                                                                                                 |                                    |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
|                                | Timer clock = CK_CNT                                                                                                            |                                    |
|                                | Counter register                                                                                                                | 0003 0002 0001 0000 0001 0002 0003 |
|                                | Counter underflow                                                                                                               |                                    |
|                                | Update event (UEV)                                                                                                              |                                    |
| Upd                            | ate interrupt flag(UDITF)                                                                                                       |                                    |
| Ţ                              | divided<br>CK_PSC<br>mer clock = CK_CNT<br>Counter register<br>Counter underflow<br>Update event (UEV)<br>interrupt flag(UDITF) |                                    |



| Figure 9-7 A center-aligned sequence diagram that includes counter overflows and underflo | ws(ARPEN - 1)              |
|-------------------------------------------------------------------------------------------|----------------------------|
| Figure 2-7 A center-anglieu sequence ulagram that menutes counter overnows and underno    | $m_{0}$ (mixi $E_{1} = 1)$ |



## 9.3.3 Clock selection

- The internal clock of timers : CK\_INT
- Two kinds of external clock mode :



- external input pin
- external trigger input ETR
- Internal trigger input (ITRx): one timer is used as a prescaler for another timer.

### 9.3.3.1 Internal clock source (CK\_INT)

When the TIMx\_SMCTRL.SMSEL is equal to "000", the slave mode controller is disabled. The three control bits (TIMx\_CTRL1.CNTEN、TIMx\_CTRL1. DIR、TIMx\_EVTGEN. UDGN) can only be changed by software (except TIMx\_EVTGEN. UDGN, which remains cleared automatically ). It is provided that the TIMx\_CTRL1.CNTEN bit is written as' 1 ' by soft, the clock source of the prescaler is provided by the internal clock CK\_INT.



#### Figure 9-8 Control circuit in normal mode, internal clock divided by 1



### 9.3.3.2 External clock source mode 1

#### Figure 9-9 TI2 external clock connection example



This mode is selected by configuring TIMx\_SMCTRL.SMSEL=111. The counter can be configured to count on the rising or falling edge of the clock at the selected input.

For example, to configure up-counting mode to count on the rising edge of the clock at the TI2 input, the configuration steps are as follows:

- Configure TIMx\_CCMOD1.CC2SEL equal to '01', CC2 channel is configured as input, IC2 is mapped to TI2
- Configure TIMx\_CCEN.CC2P equal to '0', select clock rising edge polarity
- To select input filter bandwidth by configuring TIMx\_CCMOD1.IC2F[3:0] (if filter is not needed, keep IC2F bit at '0000')
- Configure TIMx\_SMCTRL.SMSEL equal to '111', select timer external clock mode 1
- Configure TIMx\_SMCTRL.TSEL equal to '110', select TI2 as the trigger input source
- Configure TIMx\_CTRL1.CNTEN equal to '1' to start the counter

Note: The capture prescaler is not used for triggering, so it does not need to be configured

When the rising edge of the timer clock occurs at TI2=1, the counter counts once and the TIMx\_STS .TITF flag is pulled high.

The delay between the rising edge of TI2 and the actual clock of the counter depends on the resynchronization circuit at the input of TI2.







### 9.3.3.3 External clock source mode 2

This mode is selected by TIMx\_SMCTRL.EXCEN equal to 1. The counter can count on every rising or falling edge of the external trigger input ETR.

The following figure is a schematic diagram of the external trigger input module in External clock source mode 2

Figure 9-11 External trigger input block diagram



For example, use the following configuration steps to make the up counter count every 2 rising edges on ETR.

- Since no filter is needed in this case, make TIMx\_SMCTRL .EXTF[3:0] equal to '0000'
- Configure the prescaler by making TIMx\_SMCTRL.EXTPS[1:0] equal to '01'
- Select the polarity on ETR pin by setting TIMx\_SMCTRL.EXTP equal to '0', The rising edge of ETR is valid
- External clock mode 2 is selected by setting TIMx\_SMCTRL .EXCEN equal to '1'

179 / 319



■ Turn on the counter by setting TIMx\_CTRL1. CNTEN equal to '1'

The counter counts every 2 rising edges of ETR. The delay between the rising edge of ETR and the actual clock to the counter is due to a resynchronization circuit on the ETRP signal.





## 9.3.4 Capture/compare channels

Capture/compare channels include capture/compare registers and shadow registers. The input section consists of digital filters, multiplexers and prescalers. The output section includes comparators and output controls.

The input signal TIx is sampled and filtered to generate the signal TIxF. A signal (TIxF\_rising or TIxF\_falling) is then generated by the edge detector of the polarity select function, the polarity of which is selected by the TIMx\_CCEN.CCxP bits. This signal can be used as a trigger input for the slave mode controller. At the same time, the signal ICx is sent to the capture register after frequency division. The following figure shows a block diagram of a capture/compare channel.





#### Figure 9-13 Capture/compare channel (example: channel 1 input stage)

The output part generates an intermediate waveform OCxRef (active high) as reference. The polarity acts at the end of the chain.













Reads and writes always access preloaded registers when capturing/comparing. The two specific working processes are as follows:

In capture mode, the capture is actually done in the shadow register, and then the value in the shadow register is copied into the preload register.

In compare mode, as opposed to capture mode, the value of the preload register is copied into the shadow register, which is compared with the counter.

## 9.3.5 Input capture mode

In capture mode, the TIMx\_CCDATx registers are used to latch the counter value after the ICx signal detects.

There is a capture interrupt flag TIMx\_STS.CCxITF, which can issue an interrupt if the corresponding interrupt enable is pulled high.

The TIMx\_STS. CCxITF bit is set by hardware when a capture event occurs and is cleared by software or by reading the TIMx\_CCDATx register.

The overcapture flag TIMx\_STS.CCxOCF is set equal to 1 when the counter value is captured in the TIMx\_CCDATx register and TIMx\_STS.CC1ITF is already pulled high. Unlike the former, TIMx\_STS.CCxOCF is cleared by writing 0 to it.

To achieve a rising edge of the TI1 input to capture the counter value into the TIMx\_CCDAT1 register, the configuration flow is as follows:

■ To select a valid input:

Configure TIMx\_CCMOD1.CC1SEL to '01'. At this time, the input is the CC1 channel, and IC1 is mapped to TI1.

■ Program the desired input filter duration:

Define the sampling frequency of the TI1 input and the length of the digital filter by configuring the

183 / 319



TIMx\_CCMODx.ICxF bits. Example: If the input signal jitters up to 5 internal clock cycles, we must choose a filter duration longer than these 5 clock cycles. When 8 consecutive samples (sampled at f<sub>DTS</sub> frequency) with the new level are detected, we can validate the transition on TI1. Then configure TIMx\_CCMOD1. IC1F to '0011'.

- By configuring TIMx\_CCEN .CC1P=0, select the rising edge as the valid transition polarity on the TI1 channel.
- Configure the input prescaler. In this example, configure TIMx\_CCMOD1.IC1PSC= '00' to disable the prescaler because we want to capture every valid transition.
- Enable capture by configuring TIMx\_CCEN. CC1EN = '1'.

If you want enable related interrupt request, you can configureTIMx\_DINTEN.CC1IEN bit=1

## 9.3.6 **PWM input mode**

There are some differences between PWM input mode and normal input capture mode, including:

- Two ICx signals are mapped to the same TIx input.
- The two ICx signals are active on edges of opposite polarity.
- Select one of two TIxFP signals as trigger input.
- The slave mode controller is configured in reset mode.

For example, the following configuration flow can be used to know the period and duty cycle of the PWM signal on TI1 (It depends on the frequency of CK\_INT and the value of the prescaler).

- Configure TIMx\_CCMOD1.CC1SEL equal to '01' to select TI1 as valid input for TIMx\_CCDAT1.
- Configure TIMx\_CCEN.CC1P equal to '0' to select the active polarity of filtered timer input 1(TI1FP1), valid on the rising edge.
- Configure TIMx\_CCMOD1.CC2SEL equal to '10' select TI1 as valid input for TIMx\_CCDAT2.
- Configure TIMx\_CCEN.CC2P equal to 1 to select the valid polarity of filtered timer input 2(TI1FP2), valid on the falling edge.
- Configure TIMx\_SMCTRL.TSEL=101 to select Filtered timer input 1 (TI1FP1) as valid trigger input.
- Configure TIMx\_SMCTRL.SMSEL=100 to configure the slave mode controller to reset mode.
- Configure TIMx\_CCEN. CC1EN=1 and TIMx\_CCEN.CC2EN=1 to enable capture.







Because of only filter timer input 1 (TI1FP1) and filter timer input 2 (TI2FP2) are connected to the slave mode controller, the PWM input mode can only be used with the TIMx\_CH1/TIMx\_CH2 signals.

## 9.3.7 Forced output mode

Software can force output compare signals to active or inactive level directly, in output mode (TIMx\_CCMODx.CCxSEL=00).

User can set TIMx\_CCMODx. OCxMD=101 to force the output compare signal to active level. And the OCxREF will be forced high, OCx get opposite value to CCxP polarity bit. On the other hand, user can set TIMx\_CCMODx. OCxMD=100 to force the output compare signal to inactive level.

The values of the TIMx\_CCDATx shadow register and the counter still comparing with each other in this mode. And the flag still can be set. Therefore, the interrupt still can be sent.

The comparison between the output compare register TIMx\_CCDATx and the counter TIMx\_CNT has no effect on OCxREF. And the flag still can be set. Therefore, the interrupt still can be sent.

## 9.3.8 **Output compare mode**

User can use this mode to control the output waveform, or to indicate that a period of time has elapsed.

When the capture/compare register and the counter have the same value, the output compare function's operations are as follow:

■ TIMx\_CCMODx.OCxMD is for output compare mode, and TIMx\_CCEN.CCxP is for output polarity. When

185 / 319



the compare matches, if set TIMx\_CCMODx.OCxMD=000, the output pin will keep its level; if set TIMx\_CCMODx.OCxMD=001, the output pin will be set active; if set TIMx\_CCMODx.OCxMD=010, the output pin will be set inactive; if set TIMx\_CCMODx.OCxMD=011, the output pin will be set to toggle.

- Set TIMx\_STS.CCxITF.
- If user set TIMx\_DINTEN.CCxIEN, a corresponding interrupt will be generated.

User can set TIMx\_CCMODx.OCxPEN to choose capture/compare shawdow register using capture/compare preload registers(TIMx\_CCDATx) or not.

The time resolution is one count of the counter.

In one pulse mode, the output compare mode can also be used to output a single pulse.

Here are the configuration steps for output compare mode:

- First of all, user should select the counter clock.
- Secondly, set TIMx\_AR and TIMx\_CCDATx with desired data.
- If user need to generate an interrupt, set TIMx\_DINTEN.CCxIEN.
- Then select the output mode by set TIMx\_CCEN.CCxP, TIMx\_CCMODx.OCxMD, TIMx\_CCEN.CCxEN, etc.
- At last, set TIMx\_CTRL1.CNTEN to enable the counter.

User can update the output waveform by setting TIMx\_CCDATx at any time, as long as the preload register is not enabled. Otherwise the TIMx\_CCDATx shadow register will be updated at the next update event.

Here is an example.

#### Figure 9-17 Output compare mode, toggle on OC1





## 9.3.9 **PWM mode**

User can use PWM mode to generate a signal whose duty cycle is determined by the value of the TIMx\_CCDATx register and whose frequency is determined by the value of the TIMx\_AR register. And depends on the value of TIMx\_CTRL1.CAMSEL, the TIM can generate PWM signal in edge-aligned mode or center-aligned mode.

User can set PWM mode 1 or PWM mode 2 by setting TIMx\_CCMODx. OCxMD=110 or setting TIMx\_CCMODx. OCxMD=111. To enable preload register, user must set corresponding TIMx\_CCMODx.OCxPEN. And then set TIMx\_CTRL1.ARPEN to auto-reload preload register eventually.

User can set polarity of OCx by setting TIMx\_CCEN.CCxP. To enable the output of OCx, user need to set the combination of the value of CCxEN.

The values of TIMx\_CNT and TIMx\_CCDATx are always compared with each other when the TIM is under PWM mode.

Only if an update event occurs, the preload register will transfer to the shadow register. Therefore user must reset all the registers by setting TIMx\_EVTGEN.UDGN before the counter starts counting.

### 9.3.9.1 **PWM center-aligned mode**

If user set TIMx\_CTRL1.CAMSEL equal 01, 10 or 11, the PWM center-aligned mode will be active. The setting of the compare flag depends on the value of TIMx\_CTRL1.CAMSEL. There are three kinds of situation that the compare flag is set, only when the counter counts up, only when the counter counts down, or when the counter counts up and counts down. User should not modified TIMx\_CTRL1.DIR by software, it is updated by hardware.

Examples of center-aligned PWM waveforms is as follow, and the setting of the waveform are: TIMx\_AR=8, PWM mode 1, the compare flag is set when the counter counts down corresponding to TIMx\_CTRL1. CAMSEL=01.





#### Figure 9-18 Center-aligned PWM waveform (AR=8)

Notes that user should know when using center-aligned mode are as follow:

- It depends on the value of TIMx\_CTRL1.DIR that the counter counts up or down. Cautions that the DIR and CAMSEL bits should not be changed at the same time.
- User should not write the counter while running in center-aligned mode, otherwise it will cause unexpected results. Here are some example:
  - If the value written into the counter is 0 or is the value of TIMx\_AR, the direction will be updated but the update event will not be generated.
  - If the value written into the counter is greater than the value of auto-reload, the direction will not be updated.
- To be on the safe side, user is suggested setting TIMx\_EVTGEN.UDGN to generate an update by software before starting the counter, and not writing the counter while it is running.

### 9.3.9.2 **PWM edge-aligned mode**

There are two kinds of configuration in edge-aligned mode, up-counting and down-counting.

### • Up-counting



User can set TIMx\_CTRL1.DIR=0 to make counter counts up.

Here is an example for PWM mode1.

When  $TIMx_CNT < TIMx_CCDATx$ , the reference PWM signal OCxREF is high. Otherwise it will be low. If the compare value in  $TIMx_CCDATx$  is greater than the auto-reload value, the OCxREF will remains 1. Conversely, if the compare value is 0, the OCxREF will remains 0.

When TIMx\_AR=8, the PWM waveforms are as follow.



#### Figure 9-19 Edge-aligned PWM waveform (APR=8)

#### • Down-counting

User can set TIMx\_CTRL1.DIR=1 to make counter counts down.

Here is an example for PWM mode1.

When  $TIMx_CNT > TIMx_CCDATx$ , the reference PWM signal OCxREF is low. Otherwise it will be high. If the compare value in  $TIMx_CCDATx$  is greater than the auto-reload value, the OCxREF will remains 1.

Note: If the nth PWM cycle CCDATx shadow register >= AR value, the shadow register value of CCDATx in the (n+1)th PWM cycle is 0. At the moment when the counter is 0 in the (n+1)th PWM cycle, although the value of the counter = CCDATx shadow register = 0 and OCxREF = '0', no compare event will be generated.

### 9.3.10 **One-pulse mode**

In the one-pulse mode (ONEPM), a trigger signal is received, and a pulse tPULSE with a controllable pulse width is

189 / 319



generated after a controllable delay t<sub>DELAY</sub>. The output mode needs to be configured as output compare mode or PWM mode. After selecting one-pulse mode, the counter will stop counting after the update event UEV is generated.



Figure 9-20 Example of One-pulse mode

The following is an example of a one-pulse mode:

A rising edge trigger is detected from the TI2 input, and a pulse with a width of  $t_{PULSE}$  is generated on OC1 after a delay of  $t_{DELAY}$ .

1. Counter configuration: count up, counter  $TIMx_CNT < TIMx_CCDAT1 \le TIMx_AR$ ;

2. TI2FP2 is mapped to TI2, TIMx\_CCMOD1.CC2SEL= '01'; TI2FP2 is configured for rising edge detection, TIMx\_CCEN.CC2P= '0';

3. TI2FP2 acts as the trigger (TRGI) of the slave mode controller and starts the counter, TIMx\_SMCTRL.TSEL= '110', TIMx\_SMCTRL.SMSEL= '110' (trigger mode);

4. TIMx\_CCDAT1 writes the count value to be delayed (t<sub>DELAY</sub>), TIMx\_AR - TIMx\_CCDAT1 is the count value of the pulse width t<sub>PULSE</sub>;

5. Configure TIMx\_CTRL1.ONEPM=1 to enable single pulse mode, configure TIMx\_CCMOD1.OC1MD = '111' to select PWM2 mode;

6. Wait for an external trigger event on TI2, and a one pulse waveform will be output on OC1;

### 9.3.10.1 Special case: OCx fast enable:

In one-pulse mode, an edge is detected through the TIx input, and triggers the start of the counter to count to the

190 / 319



comparison value and then output a pulse. These operations limit the minimum delay t<sub>DELAY</sub> that can be achieved.

You can set TIMx\_CCMODx.OCxFEN=1 to turn on OCx fast enable, after triggering the rising edge, the OCxREF signal will be forced to be converted to the same level as the comparison match occurs immediately, regardless of the comparison result. OCxFEN fast enable only takes effect when the channel mode is configured for PWM1 and PWM2 modes.

## 9.3.11 Clearing the OCxREF signal on an external event

If user set TIMx\_CCMODx.OCxCEN=1, high level of ETRF input can be used to driven the OCxREF signal to low, and the OCxREF signal will remains low, until the next UEV happens. Only output compare and PWM modes can use this function. This cannot be used when it is in forced mode.

Here is an example for it. To control the current, user can connect the ETR signal to the output of a comparator, and the operation for ETR should be as follow:

- Set TIMx\_SMCTRL.EXTPS=00 to disable the external trigger prescaler.
- Set TIMx\_SMCTRL.EXCEN=0 to disable the external clock mode 2.
- Set TIMx\_SMCTRL.EXTP and TIMx\_SMCTRL.EXTF to configure the external trigger polarity and external trigger filter according to the need.

Here is an example for the case that when ETRF input becomes high, the behavior of OCxREF signal for different value of OCxCEN. Timer is set to be in PWM mode in this case.



#### Figure 9-21 Control circuit in reset mode



## 9.3.12 **Debug mode**

When the microcontroller is in debug mode (the Cortex-M0 core halted), depending on the DBG\_CTRL.TIMx\_STOP configuration in the PWR module, the TIMx counter can either continue to work normally or stop. For more details, see 3.4.9.

## 9.3.13 TIMx and external trigger synchronization

Same with advanced-control timer, see 8.3.16

## 9.3.14 **Timer synchronization**

All TIMx timers are internally connected to each other. This implementation allows any master timer to provide trigger to reset, start, stop or provide a clock for the other slave timers. The master clock is used for internal counter and can be prescaled. Below figure shows a Block diagram of timer interconnection.

The synchronization function does not support dynamic change of the connection. User should configure and enable the slave timer before enable the master timer's trigger or clock.



### Figure 9-22 Block diagram of timer interconnection

### 9.3.14.1 Master timer as a prescaler for another timer

TIM1 as a prescaler for TIM3. TIM1 is maser, TIM3 is slave.

User need to do the following steps for this configuration.

■ Setting TIM1\_CTRL2.MMSEL=' 010' to use the update event of TIM1 as trigger output.

192 / 319



- Configure TIM3\_SMCTRL. TSEL= '000', connect the TRGO of TIM1 to TIM3.
- Configure TIM3\_SMCTRL.SMSEL = '111', the slave mode controller will be configured in external clock mode 1.
- Start TIM3 by setting TIM3\_CTRL1. CNTEN = '1'.
- Start TIM1 by setting TIM1\_CTRL1. CNTEN = '1'.

Note: If user select OCx as the trigger output of TIM1 by configuring MMSEL = '1xx', OCx rising edge will be used to drive TIM3.

### 9.3.14.2 Master timer to enable another timer

In this example, TIM3 is enabled by the output compare of TIM1. TIM3 counter will start to count after the OC1REF output from TIM1 is high. Both counters are clocked based on CK\_INT via a prescaler divide by 3 is performed ( $f_{CK\_CNT} = f_{CK\_INT}/3$ ).

The configuration steps are shown as below.

- Setting TIM1\_CTRL2.MMSEL='100' to use the OC1REF of TIM1 as trigger output.
- Configure TIM1\_CCMOD1 register to configure the OC1REF output waveform.
- Setting TIM3\_SMCTRL.TSEL = '000' to connect TIM1 trigger output to TIM3.
- Setting TIM3\_SMCTRL.SMSEL= '101' to set TIM3 to gated mode.
- Setting TIM3\_CTRL1.CNTEN= '1' to start TIM3.
- Setting TIM1\_CTRL1.CNTEN= '1' to start TIM1.

Note: The TIM3 clock is not synchronized with the TIM1 clock, this mode only affects the TIM3 counter enable signal.

Figure 9-23 TIM3 gated by OC1REF of TIM1



Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



In the next example, Gated TIM3 with enable signal of TIM1, Setting TIM1.CTRL1.CNTEN = '0' to stop TIM1. TIM3 counts on the divided internal clock only when TIM1 is enable. Both counters are clocked based on CK\_INT via a prescaler divide by 3 is performed ( $f_{CK_{CNT}} = f_{CK_{INT}/3}$ ).

The configuration steps are shown as below

- Setting TIM1\_CTRL2.MMSEL='001' to use the enable signal of TIM1 as trigger output
- Setting TIM3\_SMCTRL.TSEL = '000' to configure TIM3 to get the trigger input from TIM1
- Setting TIM3\_SMCTRL.SMSEL = '101' to configure TIM3 in gated mode.
- Setting TIM3\_CTRL1.CNTEN= '1' to start TIM3.
- Setting TIM1\_CTRL1.CNTEN= '1' to start TIM1.
- Setting TIM1\_CTRL1.CNTEN= '0' to stop TIM1.

#### Figure 9-24 TIM3 gated by enable signal of TIM1



### 9.3.14.3 Master timer to start another timer

In this example, we can use update event as trigger source.TIM1 is master, TIM3 is slave.

The configuration steps are shown as below:

- Setting TIM1\_CTRL2.MMSEL=' 010' to use the update event of TIM1 as trigger output
- Configure TIM1\_AR register to set the output period.
- Setting TIM3\_SMCTRL .TSEL= '000' to connect TIM1 trigger output to TIM3.
- Setting TIM3\_SMCTRL. SMSEL = '110' to set TIM3 to trigger mode.
- Setting TIM1\_CTRL1.CNTEN=1 to start TIM1.







### 9.3.14.4 Start 2 timers synchronously using an external trigger

In this example, TIM1 is enabled when TIM1's TI1 input rises, and TIM3 is enabled when TIM1 is enabled. To ensure the alignment of counters, TIM1 must be configured in master/slave mode. For TI1, TIM1 is the slave; for TIM3, TIM1 is the master.

The configuration steps are shown as below:

- Setting TIM1.MMSEL = '001' to use the enable signal as trigger output
- Setting TIM1\_SMCTRL.TSEL = '100' to configure the TIM1 to slave mode and receive the trigger input of TI1.
- Setting TIM1\_SMCTRL .SMSEL = '110' to configure TIM1 to trigger mode.
- Setting TIM1\_SMCTRL .MSMD = '1' to configure TIM1 to master/slave mode.
- Setting TIM3\_SMCTRL .TSEL = '000' to connect TIM1 trigger output to TIM3.
- Setting TIM3\_SMCTRL.SMSEL = '110' to configure TIM3 to trigger mode.

When TI1 rising edge arrives, both timers start counting synchronously according to the internal clock, and both TITF flags are set simultaneously.

The following figure shows a delay between CNTEN and CK\_PSC of TIM1 in master/slave mode.







# **9.4 TIMx register description(x=3)**

## 9.4.1 **Register Overview**



#### Table 9-1 Register overview

#### Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



|         | Reset Value              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |           |   |        | -             |             |          | 0         |           |        | 0           | 0      | 0          |
|---------|--------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-----------|---|--------|---------------|-------------|----------|-----------|-----------|--------|-------------|--------|------------|
| 010h    | TIMx_STS                 | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |           |   |        | CC20CF        | CCIOCF      | Reserved | TITF      | Dacantad  |        | CC2ITF      | CCHTF  | UDITF      |
|         | Reset Value              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |           |   |        | 0             | 0           |          | 0         |           |        | 0           | 0      | 0          |
| 014h    | TIMx_EVTGEN              | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |           |   |        |               |             |          | NDL       | Dacamad   |        | CC2GN       | CCIGN  | NDGN       |
|         | Reset Value              | -        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |           |   | 1      |               | P           |          | 0         |           | -<br>- | 0           | 0      | 0          |
|         | TIMx_CCMOD1              | Reserved | <b>OC2CEN</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   | OC2M[2:0] |   | OC2PEN | <b>OC2FEN</b> | CC2SEL[1:0] | OCICEN   |           | OC1M[2:0] | OCIPEN | OCIFEN      |        | [out]merco |
| 018h    | Reset Value              |          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 | 0         | 0 | 0      | 0             | 0 0         | 0        | 0         | 0 0       | 0      | 0           | 0      | 0          |
|         | TIMx_CCMOD1              | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   | IC2F[3:0] |   |        | IC2PSC[1:0]   | CC2SEL[1:0] |          | ICIF[3:0] |           |        | IC1PSC[1:0] |        | [ou]meiroo |
|         | Reset Value              |          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 | 0         | 0 | 0      | 0             | 0 0         | 0        | 0         | 0 0       |        | 0           | 0      | 0          |
| 020h    | TIMx_CCEN<br>Reset Value | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |           |   |        |               |             |          |           | o CC2P    |        | Reserved    | o CCIP | o CCIEN    |
| 024h    | TIMx_CNT                 | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |           |   |        |               | r - 1       | [15:0]   |           |           |        |             |        |            |
|         | Reset Value              |          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 | 0         | 0 | 0      | 0             | 0 0         | 0        | 0         | 0 0       | 0      | 0           | 0      | 0          |
| 028h    | TIMx_PSC                 | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   | -         | _ |        | -             | PSC         | [15:0]   |           |           |        |             |        |            |
|         | Reset Value              |          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 | 0         | 0 | 0      | 0             | 0 0         | 0        | 0         | 0 0       | 0      | 0           | 0      | 0          |
| 02Ch    | TIMx_AR                  | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |           |   |        |               | AR[         | 15:0]    |           |           |        |             |        |            |
|         | Reset Value              |          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 | 0         | 0 | 0      | 0             | 0 0         | 0        | 0         | 0 0       | 0      | 0           | 0      | 0          |
| 030h    |                          | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |           |   |        |               |             |          |           |           |        |             |        |            |
| 034h    | TIMx_CCDAT1              | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |           |   |        |               | CCDA        |          |           |           |        |             |        |            |
| 0.0 .11 | Reset Value              |          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 | 0         | 0 | 0      | 0             | 0 0         | 0        | 0         | 0 0       | 0      | 0           | 0      | 0          |
| 038h    | TIMx_CCDAT2              | Reserved | CCDAT2[15:0]           0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 <t< td=""><td>0</td></t<> |   |           |   |        |               |             |          |           | 0         |        |             |        |            |
|         | Reset Value              |          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 | 0         | 0 | 0      | 0             | 0 0         | 0        | 0         | 0 0       | 0      | 0           | 0      | 0          |

# 9.4.2 Control register 1 (TIMx\_CTRL1)

Offset address: 0x00

Reset value: 0x0000 0000

| 31     |    |          |    |       |          |      |        |       |      |         |     |       |      |       | 16    |
|--------|----|----------|----|-------|----------|------|--------|-------|------|---------|-----|-------|------|-------|-------|
|        |    |          |    |       |          |      | Res    | erved |      | ,       |     | •     |      |       |       |
|        |    | 1        | 1  | 1     | 1        |      | 1      |       |      | 1       | 1   | 1     | 1    | 1     |       |
| 15     | 14 |          | 12 | 11    | 10       | 9    | 8      | 7     | 6    | 5       | 4   | 3     | 2    | 1     | 0     |
| CLRSEL |    | Reserved | 1  | C1SEL | Reserved | CLKI | D[1:0] | ARPEN | CAMS | EL[1:0] | DIR | ONEPM | UPRS | UPDIS | CNTEN |
| rw     |    |          |    | rw    |          | r    | w      | rw    | r    | w       | rw  | rw    | rw   | rw    | rw    |

| Bit field | Name     | Description                                         |  |  |  |
|-----------|----------|-----------------------------------------------------|--|--|--|
| 31:16     | Reserved | Reserved, the reset value must be maintained        |  |  |  |
| 15        | CLRSEL   | OCxREF clear selection                              |  |  |  |
|           |          | ): Select the external OCxREF clear from ETR        |  |  |  |
|           |          | 1: Select the internal OCxREF clear from comparator |  |  |  |
| 14:12     | Reserved | Reserved, the reset value must be maintained        |  |  |  |

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| Bit field | Name        | Description                                                                                          |
|-----------|-------------|------------------------------------------------------------------------------------------------------|
| 11        | C1SEL       | Channel 1 selection                                                                                  |
|           |             | 0: Select external CH1 signal from IOM                                                               |
|           |             | 1: Select internal CH1 signal from COMP                                                              |
| 10        | Reserved    | Reserved, the reset value must be maintained                                                         |
| 9:8       | CLKD[1:0]   | Clock division                                                                                       |
|           |             | CLKD[1:0] indicates the division ratio between CK_INT (timer clock) and t <sub>DTS</sub> (clock used |
|           |             | for dead-time generator and 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, do not use this configuration                                                          |
| 7         | ARPEN       | ARPEN: Auto-reload preload enable                                                                    |
|           |             | 0: Shadow register disable for TIMx_AR register                                                      |
|           |             | 1: Shadow register enable for TIMx_AR register                                                       |
| 6:5       | CAMSEL[1:0] | Center-aligned mode selection                                                                        |
|           |             | 00: Edge-aligned mode. TIMx_CTRL1.DIR specifies up-counting or down-counting.                        |
|           |             | 01: Center-aligned mode 1. The counter counts in center-aligned mode, and the output                 |
|           |             | compare interrupt flag bit is set to 1 when down-counting.                                           |
|           |             | 10: Center-aligned mode 2. The counter counts in center-aligned mode, and the output                 |
|           |             | compare interrupt flag bit is set to 1 when up-counting.                                             |
|           |             | 11: Center-aligned mode 3. The counter counts in center-aligned mode, and the output                 |
|           |             | compare interrupt flag bit is set to 1 when up-counting or down-counting.                            |
|           |             | Note: Switching from edge-aligned mode to center-aligned mode is not allowed when the                |
|           |             | counter is still enabled ( $TIMx\_CTRL1.CNTEN = 1$ ).                                                |
| 4         | DIR         | Direction                                                                                            |
|           |             | 0: Up-counting                                                                                       |
|           |             | 1: Down-counting                                                                                     |
|           |             | Note: This bit is read-only when the counter is configured in center-aligned mode.                   |
| 3         | ONEPM       | One-pulse mode                                                                                       |
|           |             | 0: Disable one-pulse mode, the counter counts are not affected when an update event occurs.          |
|           |             | 1: Enable one-pulse mode, the counter stops counting when the next update event occurs               |
|           |             | (clearing TIMx_CTRL1.CNTEN bit)                                                                      |
| 2         | UPRS        | Update request source                                                                                |
|           |             | This bit is used to select the UEV event sources by software.                                        |
|           |             | 0: If update interrupt is enabled, any of the following events will generate an update interrupt:    |
|           |             | – Counter overflow/underflow                                                                         |
|           |             | <ul> <li>The TIMx_EVTGEN.UDGN bit is set</li> </ul>                                                  |
|           |             | <ul> <li>Update generation from the slave mode controller</li> </ul>                                 |
|           |             | 1: If update interrupt is enabled, only counter overflow/underflow will generate update              |
|           |             | interrupt                                                                                            |



| Bit field | Name  | Description                                                                              |  |  |  |  |
|-----------|-------|------------------------------------------------------------------------------------------|--|--|--|--|
| 1         | UPDIS | Update disable                                                                           |  |  |  |  |
|           |       | This bit is used to enable/disable the Update event (UEV) events generation by software. |  |  |  |  |
|           |       | 0: Enable UEV. And UEV will be generated if one of following condition been fulfilled:   |  |  |  |  |
|           |       | - Counter overflow/underflow                                                             |  |  |  |  |
|           |       | <ul> <li>The TIMx_EVTGEN.UDGN bit is set</li> </ul>                                      |  |  |  |  |
|           |       | <ul> <li>Update generation from the slave mode controller</li> </ul>                     |  |  |  |  |
|           |       | Shadow registers will update with preload value.                                         |  |  |  |  |
|           |       | 1: UEV disabled. No update event is generated, and the shadow registers (AR, PSC, and    |  |  |  |  |
|           |       | CCDATx) keep their values. If the TIMx_EVTGEN.UDGN bit is set or a hardware reset is     |  |  |  |  |
|           |       | issued by the slave mode controller, the counter and prescaler are reinitialized.        |  |  |  |  |
| 0         | CNTEN | Counter Enable                                                                           |  |  |  |  |
|           |       | 0: Disable counter                                                                       |  |  |  |  |
|           |       | 1: Enable counter                                                                        |  |  |  |  |
|           |       | Note: external clock, gating mode can only work after TIMx_CTRL1.CNTEN bit is set in the |  |  |  |  |
|           |       | software. Trigger mode can automatically set TIMx_CTRL1.CNTEN bit by hardware.           |  |  |  |  |

# 9.4.3 Control register 2 (TIMx\_CTRL2)

Offset address: 0x04



| Bit field | Name       | Description                                                                                    |  |  |  |  |  |
|-----------|------------|------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 15:9      | Reserved   | Reserved, the reset value must be maintained                                                   |  |  |  |  |  |
| 8         | ETRSEL     | External Triggered Selection storage (ETR Selection)                                           |  |  |  |  |  |
|           |            | 0: Select external ETR (from IOM) signal;                                                      |  |  |  |  |  |
|           |            | 1: Reserved                                                                                    |  |  |  |  |  |
| 7         | Reserved   | Reserved, the reset value must be maintained                                                   |  |  |  |  |  |
| 6:4       | MMSEL[2:0] | Master Mode Selection                                                                          |  |  |  |  |  |
|           |            | These 3 bits (TIMx_CTRL2. MMSEL [2:0]) are used to select the synchronization information      |  |  |  |  |  |
|           |            | (TRGO) sent to the slave timer in the master mode. Possible combinations are as follows:       |  |  |  |  |  |
|           |            | 000: Reset -When the TIMx_EVTGEN.UDGN is set or a reset is generated by the slave mode         |  |  |  |  |  |
|           |            | controller, a TRGO pulse occurs. And in the latter case, the signal on TRGO is delayed         |  |  |  |  |  |
|           |            | compared to the actual reset.                                                                  |  |  |  |  |  |
|           |            | 001: Enable - The TIMx_CTRL1.CNTEN bit is used as the trigger output (TRGO). Sometimes         |  |  |  |  |  |
|           |            | you need to start multiple timers at the same time or enable slave timer for a period of time. |  |  |  |  |  |



| Bit field | Name     | Description                                                                                    |
|-----------|----------|------------------------------------------------------------------------------------------------|
|           |          | The counter enable signal is set when TIMx_CTRL1.CNTEN bit is set or the trigger input in      |
|           |          | gated mode is high.                                                                            |
|           |          | When the counter enable signal is controlled by the trigger input, there is a delay on TRGO    |
|           |          | except if the master/slave mode is selected (see the description of the TIMx_SMCTRL.MSMD       |
|           |          | bit).                                                                                          |
|           |          | 010: Update - The update event is selected as the trigger output (TRGO). For example, a master |
|           |          | timer clock can be used as a slave timer prescaler.                                            |
|           |          | 011: Compare pulse - Triggers the output to send a positive pulse (TRGO) when the              |
|           |          | TIMx_STS.CC1ITF is to be set (even if it is already high), when a capture or a comparison      |
|           |          | succeeds.                                                                                      |
|           |          | 100: Compare - OC1REF signal is used as the trigger output (TRGO).                             |
|           |          | 101: Compare - OC2REF signal is used as the trigger output (TRGO).                             |
|           |          | Others: reserved                                                                               |
| 3:0       | Reserved | Reserved, the reset value must be maintained                                                   |

# 9.4.4 Slave mode control register (TIMx\_SMCTRL)

### Offset address: 0x08

| 15   | 14    | 13 12      | 11        | 8 | 7    | 6         | 4 | 3        | 2 | 0          |
|------|-------|------------|-----------|---|------|-----------|---|----------|---|------------|
| EXTP | EXCEN | EXTPS[1:0] | EXTF[3:0] | 1 | MSMD | TSEL[2:0] |   | Reserved |   | SMSEL[2:0] |
| rw   | rw    | rw         | rw        |   | rw   | rw        |   |          |   | rw         |

| Bit field | Name  | Description                                                                                       |
|-----------|-------|---------------------------------------------------------------------------------------------------|
| 15 EXTP   |       | External trigger polarity                                                                         |
|           |       | This bit is used to select whether the trigger operation is to use ETR or the inversion of ETR.   |
|           |       | 0: ETR active at high level or rising edge.                                                       |
|           |       | 1: ETR active at low level or falling edge.                                                       |
| 14        | EXCEN | External clock enable                                                                             |
|           |       | This bit is used to enable external clock mode 2, and the counter is driven by any active edge on |
|           |       | the ETRF signal in this mode.                                                                     |
|           |       | 0: External clock mode 2 disable.                                                                 |
|           |       | 1: External clock mode 2 enable.                                                                  |
|           |       | Note 1: When external clock mode 1 and external clock mode 2 are enabled at the same time, the    |
|           |       | input of the external clock is ETRF.                                                              |
|           |       | Note 2: The following slave modes can be used simultaneously with external clock mode 2: reset    |
|           |       | mode, gated mode and trigger mode; However, TRGI cannot connect to ETRF                           |
|           |       | $(TIMx\_SMCTRL.TSEL \neq '111').$                                                                 |
|           |       | Note 3: Setting the TIMx_SMCTRL.EXCEN bit has the same effect as selecting external clock         |
|           |       | mode 1 and connecting TRGI to ETRF (TIMx_SMCTRL.SMSEL = 111 and TIMx_SMCTRL.TSEL                  |
|           |       | = 111).                                                                                           |



| Bit field | Name       | Description                                                                                      |
|-----------|------------|--------------------------------------------------------------------------------------------------|
| 13:12     | EXTPS[1:0] | External trigger prescaler                                                                       |
|           |            | The frequency of the external trigger signal ETRP must be at most 1/4 of TIMxCLK frequency.      |
|           |            | When a faster external clock is input, a prescaler can be used to reduce the frequency of ETRP.  |
|           |            | 00: Prescaler disable                                                                            |
|           |            | 01: ETRP frequency divided by 2                                                                  |
|           |            | 10: ETRP frequency divided by 4                                                                  |
|           |            | 11: ETRP frequency divided by 8                                                                  |
| 11:8      | EXTF[3:0]  | External trigger filter                                                                          |
|           |            | These bits are used to define the frequency at which the ETRP signal is sampled and the          |
|           |            | bandwidth of the ETRP digital filtering. In effect, the digital filter is an event counter that  |
|           |            | generates a validate output after consecutive N events are recorded.                             |
|           |            | 0000: No filter, sampling at f <sub>DTS</sub>                                                    |
|           |            | 0001: $f_{SAMPLING} = f_{CK_INT}$ , N = 2                                                        |
|           |            | 0010: $f_{\text{SAMPLING}} = f_{\text{CK_INT}}$ , N = 4                                          |
|           |            | 0011: $f_{SAMPLING} = f_{CK_INT}$ , N = 8                                                        |
|           |            | 0100: $f_{SAMPLING} = f_{DTS}/2$ , N = 6                                                         |
|           |            | 0101: $f_{SAMPLING} = f_{DTS}/2, N = 8$                                                          |
|           |            | 0110: $f_{SAMPLING} = f_{DTS}/4$ , N = 6                                                         |
|           |            | 0111: $f_{\text{SAMPLING}} = f_{\text{DTS}}/4$ , N = 8                                           |
|           |            | 1000: $f_{SAMPLING} = f_{DTS}/8$ , N = 6                                                         |
|           |            | 1001: $f_{SAMPLING} = f_{DTS}/8$ , N = 8                                                         |
|           |            | 1010: $f_{SAMPLING} = f_{DTS}/16$ , N = 5                                                        |
|           |            | 1011: $f_{SAMPLING} = f_{DTS}/16$ , N = 6                                                        |
|           |            | 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: $f_{SAMPLING} = f_{DTS}/32$ , N = 8                                                        |
| 7         | MSMD       | Master/ Slave mode                                                                               |
|           |            | 0: No action                                                                                     |
|           |            | 1: Events on the trigger input (TRGI) are delayed to allow a perfect synchronization between the |
|           |            | current timer (via TRGO) and its slaves. This is useful when several timers are required to be   |
|           |            | synchronized to a single external event.                                                         |
| 5:4       | TSEL[2:0]  | Trigger selection                                                                                |
|           |            | These 3 bits are used to select the trigger input of the synchronous counter.                    |
|           |            | 000: Internal trigger 0 (ITR0) 100: TI1 edge detector (TI1F_ED)                                  |
|           |            | 001: Internal trigger 1 (ITR1) 101: Filtered timer input 1(TI1FP1)                               |
|           |            | 010: Internal trigger 2 (ITR2) 110: Filtered timer input 2 (TI2FP2)                              |
|           |            | 011: Internal trigger 3 (ITR3) 111: External triggered Input (ETRF)                              |
|           |            | For more details on ITRx, see Table 9-2 below.                                                   |
|           |            | Note: These bits must be changed only when not in use (e. g. TIMx_SMCTRL.SMSEL=000) to           |
|           |            | avoid false edge detection at the transition.                                                    |
| 3         | Reserved   | Reserved, the reset value must be maintained                                                     |





| Bit field | Name       | Description                                                                                          |
|-----------|------------|------------------------------------------------------------------------------------------------------|
| 2:0       | SMSEL[2:0] | Slave mode selection                                                                                 |
|           |            | When an external signal is selected, the active edge of the trigger signal (TRGI) is linked to the   |
|           |            | selected external input polarity (see input control register and control register description)       |
|           |            | 000: Disable slave mode. If TIMx_CTRL1.CNTEN = 1, the prescaler is driven directly by the            |
|           |            | internal clock.                                                                                      |
|           |            | 001: reserved.                                                                                       |
|           |            | 010: reserved.                                                                                       |
|           |            | 011: reserved.                                                                                       |
|           |            | 100: Reset mode. On the rising edge of the selected trigger input (TRGI), the counter is             |
|           |            | reinitialized and the shadow register is updated.                                                    |
|           |            | 101: Gated mode. When the trigger input (TRGI) is high, the clock of the counter is enabled. Once    |
|           |            | the trigger input becomes low, the counter stops counting, but is not reset. In this mode, the start |
|           |            | and stop of the counter are controlled.                                                              |
|           |            | 110: Trigger mode. When a rising edge occurs on the trigger input (TRGI), the counter is started     |
|           |            | but not reset. In this mode, only the start of the counter is controlled.                            |
|           |            | 111: External clock mode 1. The counter is clocked by the rising edge of the selected trigger input  |
|           |            | (TRGI).                                                                                              |
|           |            | Note: Do not use gated mode if TIIF_ED is selected as the trigger input                              |
|           |            | (TIMx_SMCTRL.TSEL=100). This is because TI1F_ED outputs a pulse for each TI1F transition,            |
|           |            | whereas gated mode checks the level of the triggered input.                                          |

| Table 9-2 TIM | internal | trigger | connection |
|---------------|----------|---------|------------|
|---------------|----------|---------|------------|

| Slave timer | ITR0 (TSEL = 000) | ITR1 (TSEL = 001) | ITR2 (TSEL = 010) | ITR3 (TSEL = 011) |  |  |
|-------------|-------------------|-------------------|-------------------|-------------------|--|--|
| TIM3        | TIM1              | NA                | NA                | NA                |  |  |

# 9.4.5 Interrupt enable registers (TIMx\_DINTEN)

Offset address: 0x0C

| 15 |       |   |          |   |   |   | 7 | 6    | 5 |          | 3 | 2      | 1      | 0    |
|----|-------|---|----------|---|---|---|---|------|---|----------|---|--------|--------|------|
|    | 1     | 1 | Reserved | 1 |   |   |   | TIEN |   | Reserved |   | CC2IEN | CC1IEN | UIEN |
|    | <br>1 |   | 1        | 1 | 1 | I | 1 | rw   |   |          |   | rw     | rw     | rw   |

| Bit field | Name     | Description                                  |
|-----------|----------|----------------------------------------------|
| 15:7      | Reserved | Reserved, the reset value must be maintained |
| 6         | TIEN     | Trigger interrupt enable                     |
|           |          | 0: Disable trigger interrupt                 |
|           |          | 1: Enable trigger interrupt                  |
| 5:3       | Reserved | Reserved, the reset value must be maintained |



| Bit field | Name   | Description                              |
|-----------|--------|------------------------------------------|
| 2         | CC2IEN | Capture/Compare 2 interrupt enable       |
|           |        | 0: Disable capture/compare 2 interrupt   |
|           |        | 1: Enables capture/compare 2 interrupts  |
| 1         | CC1IEN | Capture/Compare 1 interrupt enable       |
|           |        | 0: Disable capture/compare 1 interrupt   |
|           |        | 1: Enables capture/comparing 1 interrupt |
| 0         | UIEN   | Update interrupt enable                  |
|           |        | 0: Disable update interrupt              |
|           |        | 1: Enables update interrupt              |

# 9.4.6 Status registers (TIMx\_STS)

Offset address: 0x10

|   | 15 |   |          |   | 11 | 10     | 9      | 8    | 7     | 6     | 5 |          | 3 | 2      | 1      | 0     |
|---|----|---|----------|---|----|--------|--------|------|-------|-------|---|----------|---|--------|--------|-------|
|   |    | I | Reserved | I | 1  | CC2OCF | CC10CF | Rese | erved | TITF  |   | Reserved |   | CC2ITF | CC1ITF | UDITF |
| I |    |   |          |   |    | rc_w0  | rc_w0  |      |       | rc_w0 |   |          |   | rc_w0  | rc_w0  | rc_w0 |

| Bit field | Name     | Description                                                                                    |
|-----------|----------|------------------------------------------------------------------------------------------------|
| 15:11     | Reserved | Reserved, the reset value must be maintained                                                   |
| 10        | CC2OCF   | Capture/Compare 2 overcapture flags                                                            |
|           |          | See TIMx_STS.CC1OCF description.                                                               |
| 9         | CC10CF   | Capture/Compare 1 overcapture flag                                                             |
|           |          | This bit is set by hardware only when the corresponding channel is configured in input capture |
|           |          | mode. Cleared by software writing 0.                                                           |
|           |          | 0: No overcapture occurred                                                                     |
|           |          | 1: TIMx_STS.CC1ITF was already set when the value of the counter has been captured in the      |
|           |          | TIMx_CCDAT1 register.                                                                          |
| 8:7       | Reserved | Reserved, the reset value must be maintained                                                   |
| 6         | TITF     | Trigger interrupt flag                                                                         |
|           |          | This bit is set by hardware when an active edge is detected on the TRGI input when the slave   |
|           |          | mode controller is in a mode other than gated. This bit is set by hardware when any edge in    |
|           |          | gated mode is detected. This bit is cleared by software.                                       |
|           |          | 0: No trigger event occurred                                                                   |
|           |          | 1: Trigger interrupt occurred                                                                  |
| 5:3       | Reserved | Reserved, the reset value must be maintained                                                   |
| 2         | CC2ITF   | Capture/Compare 2 interrupt flag                                                               |
|           |          | See TIMx_STS.CC1ITF description.                                                               |
| 1         | CC1ITF   | Capture/Compare 1 interrupt flag                                                               |
|           |          | When the corresponding channel of CC1 is in output mode:                                       |



| Bit field | Name  | Description                                                                                      |
|-----------|-------|--------------------------------------------------------------------------------------------------|
|           |       | Except in center-aligned mode, this bit is set by hardware when the counter value is the same as |
|           |       | the compare value (see TIMx_CTRL1.CAMSEL bit description). This bit is cleared by                |
|           |       | software.                                                                                        |
|           |       | 0: No match occurred.                                                                            |
|           |       | 1: The value of TIMx_CNT is the same as the value of TIMx_CCDAT1.                                |
|           |       | When the value of TIMx_CCDAT1 is greater than the value of TIMx_AR, the                          |
|           |       | TIMx_STS.CC1ITF bit will go high if the counter overflows (in up-counting and up/down-           |
|           |       | counting modes) and underflows in down-counting mode.                                            |
|           |       | When the corresponding channel of CC1 is in input mode:                                          |
|           |       | This bit is set by hardware when the capture event occurs. This bit is cleared by software or by |
|           |       | reading TIMx_CCDAT1.                                                                             |
|           |       | 0: No input capture occurred.                                                                    |
|           |       | 1: Input capture occurred. Counter value has captured in the TIMx_CCDAT1. An edge with the       |
|           |       | same polarity as selected has been detected on IC1.                                              |
| 0         | UDITF | Update interrupt flag                                                                            |
|           |       | This bit is set by hardware when an update event occurs under the following conditions:          |
|           |       | - When TIMx_CTRL1.UPDIS = 0, overflow or underflow (An update event is generated).               |
|           |       | - When TIMx_CTRL1.UPRS = 0, TIMx_CTRL1.UPDIS = 0, and set the                                    |
|           |       | TIMx_EVTGEN.UDGN bit by software to reinitialize the CNT.                                        |
|           |       | - When TIMx_CTRL1.UPRS = 0, TIMx_CTRL1.UPDIS = 0, and the counter CNT is                         |
|           |       | reinitialized by the trigger event. (See TIMx_SMCTRL Register description)                       |
|           |       | This bit is cleared by software.                                                                 |
|           |       | 0: No update event occurred                                                                      |
|           |       | 1: Update interrupt occurred                                                                     |

# 9.4.7 Event generation registers (TIMx\_EVTGEN)

### Offset address: 0x14

| <br>15 | <br> |   |          | _ |  | 7 | 6   | 5 |          | 3 | 2     | 1     | 0    |
|--------|------|---|----------|---|--|---|-----|---|----------|---|-------|-------|------|
|        |      |   | Reserved |   |  |   | TGN |   | Reserved |   | CC2GN | CC1GN | UDGN |
|        | <br> | I |          |   |  |   | w   |   |          |   | w     | w     | w    |

| Bit field | Name     | Description                                                                                        |
|-----------|----------|----------------------------------------------------------------------------------------------------|
| 15: 7     | Reserved | Reserved, the reset value must be maintained.                                                      |
| 6         | TGN      | Trigger generation                                                                                 |
|           |          | This bit can generate a trigger event when set by software. And at this time TIMx_STS.TITF =       |
|           |          | 1, if the corresponding interrupt are enabled, the corresponding interrupt will be generated. This |
|           |          | bit is automatically cleared by hardware.                                                          |
|           |          | 0: No action                                                                                       |
|           |          | 1: Generated a trigger event                                                                       |
| 5:3       | Reserved | Reserved, the reset value must be maintained                                                       |



| Bit field | Name  | Description                                                                                                |
|-----------|-------|------------------------------------------------------------------------------------------------------------|
| 2         | CC2GN | Capture/Compare 2 generation                                                                               |
|           |       | See TIMx_EVTGEN.CC1GN description.                                                                         |
| 1         | CC1GN | Capture/Compare 1 generation                                                                               |
|           |       | This bit can generate a capture/compare event when set by software. This bit is automatically              |
|           |       | cleared by hardware.                                                                                       |
|           |       | When the corresponding channel of CC1 is in output mode:                                                   |
|           |       | The TIMx_STS.CC1ITF flag will be pulled high, if the corresponding interrupt are enabled, the              |
|           |       | corresponding interrupt will be generated.                                                                 |
|           |       | When the corresponding channel of CC1 is in input mode:                                                    |
|           |       | TIMx_CCDAT1 will capture the current counter value, and the TIMx_STS.CC1ITF flag will be                   |
|           |       | pulled high, if the corresponding interrupt are enabled, the corresponding interrupt will be               |
|           |       | generated. If The IMx_STS.CC1ITF is already pulled high, pull TIMx_STS.CC1OCF high.                        |
|           |       | 0: No action                                                                                               |
|           |       | 1: Generated a CC1 capture/compare event                                                                   |
| 0         | UDGN  | Update generation                                                                                          |
|           |       | This bit can generate an update event when set by software. And at this time the counter will be           |
|           |       | reinitialized, the prescaler counter will be cleared, the counter will be cleared in center-aligned or up- |
|           |       | counting mode, but take TIMx_AR in down-counting mode the value of the register. This bit is               |
|           |       | automatically cleared by hardware.                                                                         |
|           |       | 0: No action                                                                                               |
|           |       | 1: Generated an update event                                                                               |

# 9.4.8 Capture/compare mode register 1 (TIMx\_CCMOD1)

### Offset address: 0x18

Reset value: 0x0000

Channels can be used for input (capture mode) or output (compare mode), and the direction of the channel is defined by the corresponding CCxSEL bit. The other bits of the register act differently in input and output modes. OCx describes the function of a channel in output mode, ICx describes the function of a channel in input mode. Hence, please note that the same bit can have different meanings for output mode and for input mode.

Output compare mode:

| 15    |                | 14 |           | 12 | 11     | 10     | 9     | 8       | 7      | 6 |            | 4 | 3      | 2      | 1     | 0       |
|-------|----------------|----|-----------|----|--------|--------|-------|---------|--------|---|------------|---|--------|--------|-------|---------|
| OC2CE | <sup>I</sup> N | (  | DC2MD[2:0 | ]  | OC2PEN | OC2FEN | CC2SE | EL[1:0] | OC1CEN |   | OC1MD[2:0] |   | OC1PEN | OC1FEN | CC1SI | EL[1:0] |
| rw    |                |    | rw        |    | rw     | rw     | rv    | N       | rw     |   | rw         |   | rw     | rw     | r     | w       |

| Bit field | Name       | Description                     |  |  |  |  |  |  |
|-----------|------------|---------------------------------|--|--|--|--|--|--|
| 15        | OC2CEN     | Output Compare 2 clear enable   |  |  |  |  |  |  |
| 14:12     | OC2MD[2:0] | Output Compare 2 mode           |  |  |  |  |  |  |
| 11        | OC2PEN     | Output Compare 2 preload enable |  |  |  |  |  |  |
| 10        | OC2FEN     | Output Compare 2 fast enable    |  |  |  |  |  |  |



| Bit field | Name        | Description                                                                               |  |  |  |  |  |  |
|-----------|-------------|-------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 9:8       | CC2SEL[1:0] | Capture/compare 2 selection                                                               |  |  |  |  |  |  |
|           |             | These bits are used to select the input/output and input mapping of the channel           |  |  |  |  |  |  |
|           |             | 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 is only active    |  |  |  |  |  |  |
|           |             | when the internal trigger input is selected by TIMx_SMCTRL.TSEL.                          |  |  |  |  |  |  |
|           |             | Note: CC2SEL is writable only when the channel is off ( $TIMx\_CCEN.CC2EN = 0$ ).         |  |  |  |  |  |  |
| 7         | OC1CEN      | Output Compare 1 clear enable                                                             |  |  |  |  |  |  |
|           |             | 0: OC1REF is not affected by ETRF input level                                             |  |  |  |  |  |  |
|           |             | 1: OC1REF is cleared immediately when the ETRF input level is detected as high            |  |  |  |  |  |  |
| 6:4       | OC1MD[2:0]  | Output Compare 1 mode                                                                     |  |  |  |  |  |  |
|           |             | These bits are used to manage the output reference signal OC1REF, which determines the    |  |  |  |  |  |  |
|           |             | values of OC1 and OC1N, and is valid at high levels, while the active levels of OC1 and   |  |  |  |  |  |  |
|           |             | OC1N depend on the TIMx_CCEN.CC1P and TIMx_CCEN.CC1NP bits.                               |  |  |  |  |  |  |
|           |             | 000: Frozen. Comparison between TIMx_CCDAT1 register and counter TIMx_CNT has no          |  |  |  |  |  |  |
|           |             | effect on OC1REF signal.                                                                  |  |  |  |  |  |  |
|           |             | 001: Set channel 1 to the active level on match. When $TIMx\_CCDAT1 = TIMx\_CNT$ ,        |  |  |  |  |  |  |
|           |             | OC1REF signal will be forced high.                                                        |  |  |  |  |  |  |
|           |             | 010: Set channel 1 as inactive level on match. When $TIMx\_CCDAT1 = TIMx\_CNT$ ,          |  |  |  |  |  |  |
|           |             | OC1REF signal will be forced low.                                                         |  |  |  |  |  |  |
|           |             | 011: Toggle. When TIMx_CCDAT1 = TIMx_CNT, OC1REF signal will be toggled.                  |  |  |  |  |  |  |
|           |             | 100: Force to inactive level. OC1REF signal is forced low.                                |  |  |  |  |  |  |
|           |             | 101: Force to active level. OC1REF signal is forced high.                                 |  |  |  |  |  |  |
|           |             | 110: PWM mode 1 - In up-counting mode, if TIMx_CNT < TIMx_CCDAT1, OC1REF signal           |  |  |  |  |  |  |
|           |             | of channel 1 is high, otherwise it is low. In down-counting mode, if TIMx_CNT >           |  |  |  |  |  |  |
|           |             | TIMx_CCDAT1, OC1REF signal of channel 1 is low, otherwise it is high.                     |  |  |  |  |  |  |
|           |             | 111: PWM mode 2 - In up-counting mode, if TIMx_CNT < TIMx_CCDAT1, OC1REF signal           |  |  |  |  |  |  |
|           |             | of channel 1 is low, otherwise it is high. In down-counting mode, if TIMx_CNT >           |  |  |  |  |  |  |
|           |             | TIMx_CCDAT1, OC1REF signal of channel 1 is high, otherwise it is low.                     |  |  |  |  |  |  |
|           |             | Note 1: In PWM mode 1 or PWM mode 2, the OC1REF level changes only when the               |  |  |  |  |  |  |
|           |             | comparison result changes or when the output compare mode is switched from frozen mode to |  |  |  |  |  |  |
|           |             | PWM mode.                                                                                 |  |  |  |  |  |  |
| 3         | OC1PEN      | Output Compare 1 preload enable                                                           |  |  |  |  |  |  |
| 5         | o chi Liv   | 0: Disable preload function of TIMx_CCDAT1 register. Supports write operations to         |  |  |  |  |  |  |
|           |             | TIMx_CCDAT1 register at any time, and the written value is effective immediately.         |  |  |  |  |  |  |
|           |             | 1: Enable preload function of TIMx_CCDAT1 register. Only read and write operations to     |  |  |  |  |  |  |
|           |             | preload registers. When an update event occurs, the value of TIMx_CCDAT1 is loaded into   |  |  |  |  |  |  |
|           |             | the active register.                                                                      |  |  |  |  |  |  |
|           |             | <i>Note 1: Only when TIMx_CTRL1.ONEPM = 1(In one-pulse mode), PWM mode can be used</i>    |  |  |  |  |  |  |
|           |             | without verifying the preload register, otherwise no other behavior can be predicted.     |  |  |  |  |  |  |



| Bit field | Name        | Description                                                                                   |  |  |  |  |  |  |
|-----------|-------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 2         | OC1FEN      | Output Compare 1 fast enable                                                                  |  |  |  |  |  |  |
|           |             | This bit is used to speed up the response of the CC output to the trigger input event.        |  |  |  |  |  |  |
|           |             | 0: CC1 behaves normally depending on the counter and CCDAT1 values, even if the trigger is    |  |  |  |  |  |  |
|           |             | ON. The minimum delay for activating CC1 output when an edge occurs on the trigger input      |  |  |  |  |  |  |
|           |             | is 5 clock cycles.                                                                            |  |  |  |  |  |  |
|           |             | 1: An active edge of the trigger input acts like a comparison match on CC1 output. Therefore, |  |  |  |  |  |  |
|           |             | OC is set to the comparison level regardless of the comparison result. The delay time for     |  |  |  |  |  |  |
|           |             | sampling the trigger input and activating the CC1 output is reduced to 3 clock cycles.        |  |  |  |  |  |  |
|           |             | OCxFEN only works if the channel is configured in PWM1 or PWM2 mode.                          |  |  |  |  |  |  |
| 1: 0      | CC1SEL[1:0] | Capture/compare 1 selection                                                                   |  |  |  |  |  |  |
|           |             | These bits are used to select the input/output and input mapping of the channel               |  |  |  |  |  |  |
|           |             | 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 channels are configured as inputs and IC1 is mapped to TRC. This mode is only         |  |  |  |  |  |  |
|           |             | active when the internal trigger input is selected by TIMx_SMCTRL.TSEL.                       |  |  |  |  |  |  |
|           |             | Note: CC1SEL is writable only when the channel is off $(TIMx\_CCEN.CC1EN = 0)$ .              |  |  |  |  |  |  |

### Input capture mode:

| 15        | 12 | 11       | 10  | 9     | 8       | 7 |           | 4 | 3     | 2      | 1     | 0       |
|-----------|----|----------|-----|-------|---------|---|-----------|---|-------|--------|-------|---------|
| IC2F[3:0] | I  | IC2PSC[1 | :0] | CC2SE | EL[1:0] |   | IC1F[3:0] | 1 | IC1PS | C[1:0] | CC1SE | EL[1:0] |
|           |    | · · ·    | -   |       |         |   |           |   |       |        |       |         |
| rw        |    | rw       |     | ť     | N       |   | rw        |   | r     | w      | ť     | w       |

| Bit field | Name        | Description                                                                                         |  |  |  |  |  |  |
|-----------|-------------|-----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 15:12     | IC2F[3:0]   | Input Capture 2 Filter                                                                              |  |  |  |  |  |  |
| 11:10     | IC2PSC[1:0] | nput Capture 2 Prescaler                                                                            |  |  |  |  |  |  |
| 9:8       | CC2SEL[1:0] | Capture/Compare 2 selection                                                                         |  |  |  |  |  |  |
|           |             | These bits are used to select the input/output and input mapping of the channel                     |  |  |  |  |  |  |
|           |             | 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 is only active when         |  |  |  |  |  |  |
|           |             | the internal trigger input is selected by TIMx_SMCTRL.TSEL.                                         |  |  |  |  |  |  |
|           |             | Note: CC2SEL is writable only when the channel is off $(TIMx\_CCEN.CC2EN = 0)$ .                    |  |  |  |  |  |  |
| 7:4       | IC1F[3:0]   | Input Capture 1 filter                                                                              |  |  |  |  |  |  |
|           |             | These bits are used to define sampling frequency of TI1 input and the length of digital filter. The |  |  |  |  |  |  |
|           |             | digital filter is an event counter that generates an output transition after N events are recorded. |  |  |  |  |  |  |
|           |             | 0000: No filter, sampling at fDTS frequency                                                         |  |  |  |  |  |  |
|           |             | 0001: $f_{SAMPLING} = f_{CK\_INT}$ , N = 2                                                          |  |  |  |  |  |  |
|           |             | 0010: $f_{SAMPLING} = f_{CK_INT}$ , N = 4                                                           |  |  |  |  |  |  |
|           |             | 0011: $f_{SAMPLING} = f_{CK_INT}$ , N = 8                                                           |  |  |  |  |  |  |



| Bit field | Name        | Description                                                                                 |
|-----------|-------------|---------------------------------------------------------------------------------------------|
|           |             | 0100: $f_{SAMPLING} = f_{DTS}/2$ , N = 6                                                    |
|           |             | 0101: $f_{SAMPLING} = f_{DTS}/2$ , N = 8                                                    |
|           |             | 0110: $f_{SAMPLING} = f_{DTS}/4$ , N = 6                                                    |
|           |             | 0111: $f_{SAMPLING} = f_{DTS}/4$ , N = 8                                                    |
|           |             | 1000: $f_{SAMPLING} = f_{DTS}/8$ , N = 6                                                    |
|           |             | $1001: f_{SAMPLING} = f_{DTS}/8, N = 8$                                                     |
|           |             | 1010: $f_{SAMPLING} = f_{DTS}/16$ , N = 5                                                   |
|           |             | $1011: f_{SAMPLING} = f_{DTS}/16, N = 6$                                                    |
|           |             | 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: $f_{SAMPLING} = f_{DTS}/32$ , N = 8                                                   |
| 3:2       | IC1PSC[1:0] | Input Capture 1 prescaler                                                                   |
|           |             | These bits are used to select the ratio of the prescaler for IC1 (CC1 input).               |
|           |             | When $TIMx\_CCEN.CC1EN = 0$ , the prescaler will be reset.                                  |
|           |             | 00: No prescaler, capture is done each time 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                                                     |
| 1:0       | CC1SEL[1:0] | Capture/Compare 1 selection                                                                 |
|           |             | These bits are used to select the input/output and input mapping of the channel             |
|           |             | 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 to TRC. This mode is only active when |
|           |             | the internal trigger input is selected by TIMx_SMCTRL.TSEL.                                 |
|           |             | Note: CC1SEL is writable only when the channel is off $(TIMx\_CCEN.CC1EN = 0)$ .            |

# 9.4.9 Capture/compare enable registers (TIMx\_CCEN)

Offset address: 0x20

| Reserved CC2P CC2EN Reserved CC1P CC1EN | 15 |   |   |   |      |       |   |   |   | 6 | 5    | 4     | 3    | 2     | 1    | 0     |
|-----------------------------------------|----|---|---|---|------|-------|---|---|---|---|------|-------|------|-------|------|-------|
|                                         |    | 1 | 1 | 1 | Rese | erved | 1 | 1 | 1 | 1 | CC2P | CC2EN | Rese | erved | CC1P | CC1EN |
| rw rw rw rw                             |    | 1 | 1 | 1 | 1    | 1     | 1 | 1 | 1 | I |      |       |      | 1     |      |       |

| Bit field | Name     | Description                                   |
|-----------|----------|-----------------------------------------------|
| 15:6      | Reserved | Reserved, the reset value must be maintained. |
| 5         | CC2P     | Capture/Compare 2 output polarity             |
|           |          | See TIMx_CCEN.CC1P description.               |
| 4         | CC2EN    | Capture/Compare 2 output enable               |
|           |          | See TIMx_CCEN.CC1EN description.              |



| Bit field | Name     | Description                                                                                              |
|-----------|----------|----------------------------------------------------------------------------------------------------------|
| 3:2       | Reserved | Reserved, the reset value must be maintained                                                             |
| 1         | CC1P     | Capture/Compare 1 output polarity                                                                        |
|           |          | When the corresponding channel of CC1 is in output mode:                                                 |
|           |          | 0: OC1 active high                                                                                       |
|           |          | 1: OC1 active low                                                                                        |
|           |          | When the corresponding channel of CC1 is in input mode:                                                  |
|           |          | At this time, this bit is used to select whether IC1 or the inverse signal of IC1 is used as the trigger |
|           |          | or capture signal.                                                                                       |
|           |          | 0: non-inverted: Capture action occurs when IC1 generates a rising edge. When used as external           |
|           |          | trigger, IC1 is non-inverted.                                                                            |
|           |          | 1: inverted: Capture action occurs when IC1 generates a falling edge. When used as external              |
|           |          | trigger, IC1 is inverted.                                                                                |
|           |          | Note: If $TIMx\_BKDT.LCKCFG = 3 \text{ or } 2$ , these bits cannot be modified.                          |
| 0         | CC1EN    | Capture/Compare 1 output enable                                                                          |
|           |          | When the corresponding channel of CC1 is in output mode:                                                 |
|           |          | 0: Disable - Disable output OC1 signal.                                                                  |
|           |          | 1: Enable - Enable output OC1 signal.                                                                    |
|           |          | When the corresponding channel of CC1 is in input mode:                                                  |
|           |          | At this time, this bit is used to disable/enable the capture function.                                   |
|           |          | 0: Disable capture                                                                                       |
|           |          | 1: Enable capture                                                                                        |

| CCxEN | N OCx output status     |  |  |  |  |  |  |  |
|-------|-------------------------|--|--|--|--|--|--|--|
| 0     | Disable output (OCx=0)  |  |  |  |  |  |  |  |
| 1     | OCx = OCxREF + polarity |  |  |  |  |  |  |  |

Note: The state of external I/O pins connected to standard OCx channels depends on the OCx channel state and GPIO and AFIO registers.

# 9.4.10 Counters (TIMx\_CNT)

Offset address: 0x24

| 15 |     |     |   |      |       |   |   |     |   | 0 |
|----|-----|-----|---|------|-------|---|---|-----|---|---|
|    | 1 1 | 1 1 | 1 |      | 1     | 1 | 1 | 1 1 | 1 |   |
|    |     |     |   | CNT[ | 15:0] |   |   |     |   |   |
| 1  | 1 1 |     |   |      |       |   |   | 1 1 |   |   |
|    |     |     |   | rv   | v     |   |   |     |   |   |

| Bit field | Name      | Description   |
|-----------|-----------|---------------|
| 15:0      | CNT[15:0] | Counter value |



# 9.4.11 Prescaler (TIMx\_PSC)

#### Offset address: 0x28

#### Reset value: 0x0000

| 15 |  |   |   |      |      |       |   |  |   |   |     | 0 |
|----|--|---|---|------|------|-------|---|--|---|---|-----|---|
|    |  | 1 |   |      |      |       | 1 |  | 1 | 1 | 1 1 |   |
|    |  |   |   |      | PSC[ | 15:0] |   |  |   |   |     |   |
|    |  | I | 1 | <br> |      |       |   |  | 1 | L | I I |   |
|    |  |   |   |      |      |       |   |  |   |   |     |   |

| Bit field | Name      | Description                                                                                   |
|-----------|-----------|-----------------------------------------------------------------------------------------------|
| 15:0      | PSC[15:0] | Prescaler value                                                                               |
|           |           | Counter clock $f_{CK\_CNT} = f_{CK\_PSC}/(PSC [15:0] +1)$ .                                   |
|           |           | Each time an update event occurs, the PSC value is loaded into the active prescaler register. |
|           |           |                                                                                               |

# 9.4.12 Auto-reload register (TIMx\_AR)

### Offset address: 0x2C

#### Reset values: 0xFFFF

| 15 |     |  |  |     |       |  |   |   |   | 0 |
|----|-----|--|--|-----|-------|--|---|---|---|---|
| 1  | 1 1 |  |  | 1   | 1     |  |   |   | 1 |   |
|    |     |  |  | AR[ | 15:0] |  |   |   |   |   |
|    | 1 1 |  |  | 1   | 1     |  | 1 | 1 | 1 |   |
|    |     |  |  | r   | w     |  |   |   |   |   |

| Bit field | Name     | Description                                                                           |
|-----------|----------|---------------------------------------------------------------------------------------|
| 15:0      | AR[15:0] | Auto-reload value                                                                     |
|           |          | These bits define the value that will be loaded into the actual auto-reload register. |
|           |          | See Section 8.3.1 for more details.                                                   |
|           |          | When the TIMx_AR.AR [15:0] value is null, the counter does not work.                  |

# 9.4.13 Capture/compare register 1 (TIMx\_CCDAT1)

### Offset address: 0x34

| 15 |   |   |   |   |   |   |       |           |  |   |   |  | 0 |
|----|---|---|---|---|---|---|-------|-----------|--|---|---|--|---|
|    | 1 | 1 | 1 | 1 | 1 | 1 |       | 1         |  | 1 |   |  |   |
|    |   |   |   |   |   |   | CCDAT | [1][15:0] |  |   |   |  |   |
|    |   |   |   |   |   | I |       |           |  | 1 | 1 |  |   |
|    |   |   |   |   |   |   | rw    | v/r       |  |   |   |  |   |

| Bit field | Name         | Description                                                                            |
|-----------|--------------|----------------------------------------------------------------------------------------|
| 15:0      | CCDAT1[15:0] | Capture/Compare 1 value                                                                |
|           |              | CC1 channel is configured as output:                                                   |
|           |              | CCDAT1 contains the value to be compared to the counter TIMx_CNT, signaling on the OC1 |
|           |              | output.                                                                                |



| Bit field | Name | Description                                                                                           |
|-----------|------|-------------------------------------------------------------------------------------------------------|
|           |      | If the preload feature is not selected in TIMx_CCMOD1.OC1PEN bit, the written value is                |
|           |      | immediately transferred to the active register. Otherwise, this preloaded value is transferred to the |
|           |      | active register only when an update event occurs.                                                     |
|           |      | CC1 channel is configured as input:                                                                   |
|           |      | CCDAT1 contains the counter value transferred by the last input capture 1 event (IC1).                |
|           |      | When configured as input mode, register CCDAT1 is only readable.                                      |
|           |      | When configured as output mode, register CCDAT1 is readable and writable.                             |

# 9.4.14 Capture/compare register 2 (TIMx\_CCDAT2)

Offset address: 0x38

Reset value: 0x0000

| 15 |              |  |  |   |   |   |  |  |   |   |      |   | 0 |  |
|----|--------------|--|--|---|---|---|--|--|---|---|------|---|---|--|
|    |              |  |  | 1 | 1 | 1 |  |  | 1 | 1 | 1    | 1 |   |  |
|    | CCDAT2[15:0] |  |  |   |   |   |  |  |   |   |      |   |   |  |
|    |              |  |  |   |   |   |  |  |   |   | <br> |   |   |  |
|    |              |  |  |   |   |   |  |  |   |   |      |   |   |  |

rw/r

| Bit field | Name         | Description                                                                                           |
|-----------|--------------|-------------------------------------------------------------------------------------------------------|
| 15:0      | CCDAT2[15:0] | Capture/Compare 2 values                                                                              |
|           |              | CC2 channel is configured as output:                                                                  |
|           |              | CCDAT2 contains the value to be compared to the counter TIMx_CNT, signaling on the OC2                |
|           |              | output.                                                                                               |
|           |              | If the preload feature is not selected in TIMx_CCMOD1.OC2PEN bit, the written value is                |
|           |              | immediately transferred to the active register. Otherwise, this preloaded value is transferred to the |
|           |              | active register only when an update event occurs.                                                     |
|           |              | CC2 channel is configured as input:                                                                   |
|           |              | CCDAT2 contains the counter value transferred by the last input capture 2 event (IC2).                |
|           |              | When configured as input mode, register CCDAT2 is only readable.                                      |
|           |              | When configured as output mode, register CCDAT2 is readable and writable.                             |

# **10 Basic timers (TIM6)**

# **10.1 Basic timers introduction**

The basic timer contains a 16-bit counter, it also provides the ability to wake the system from a low-power mode.

## 10.2 Main features of Basic timers

- 16-bit auto-reload up-counting counters.
- 16-bit programmable prescaler. (The frequency division factor can be configured with any value between 1 and 65536)



- The events that generate the interrupt are as follows:
  - Update event
- Support STOP mode wake-up: When the clock source is configured as LSI, STOP mode can be awakened by updating interrupts (connected to EXTI19).



#### Figure 10-1 Block diagram of TIM6

## 10.3 Basic timers description

## 10.3.1 Time-base unit

The time-base unit mainly includes: prescaler, counter and auto-reload. When the time base unit is working, the software can read and write the corresponding registers (TIMx\_PSC, TIMx\_CNT and TIMx\_AR) at any time.

Note: When the clock source is configured for LSI, TIMx\_CNT does not support writes.

Depending on the setting of the auto-reload preload enable bit (TIMx\_CTRL1.ARPEN), the value of the preload register is transferred to the shadow register immediately or at each update event UEV. when TIMx\_CTRL1.UPDIS=0, an update event is generated when the counter reaches the overflow condition or the software settings TIMx\_EVTGEN.UDGN bit. The counter CK\_CNT is valid only when the TIMx\_CTRL1.CNTEN bit is set.

### 10.3.1.1 Prescaler description

The TIMx\_PSC register consists of a 16-bit counter that can be used to divide the counter clock frequency by any factor between 1 and 65536. It can be changed on the fly as it is buffered. The prescaler value is only taken into account at the next update event.





Figure 10-2 Counter timing diagram with prescaler division change from 1 to 4

## 10.3.2 **Counter mode**

### 10.3.2.1 Up-counting mode

In up-counting mode, the counter will count from 0 to the value of the register TIMx\_AR, then it resets to 0. And a counter overflow event is generated.

If the TIMx\_CTRL1.UPRS bit (select update request) and the TIMx\_EVTGEN.UDGN bit are set, an update event (UEV) will generate, and TIMx\_STS.UDITF will not be set by hardware. Therefore, no update interrupts requests are generated. This setting is used in scenarios where you want to clear the counter but do not want to generate an update interrupt.

Depending on the update request source is configured in the TIMx\_CTRL1.UPRS, When an update event occurs, all registers are updated and the TIMx\_STS.UDITF is set:

- Update auto-reload shadow registers with preload value(TIMx\_AR), when TIMx\_CTRL1.ARPEN = 1.
- The prescaler shadow register is reloaded with the preload value(TIMx\_PSC)

To avoid updating the shadow registers when new values are written to the preload registers, you can disable the update by setting TIMx\_CTRL1.UPDIS=1.

When an update event occurs, the counter will still be cleared and the prescaler counter will also be set to 0 (but the prescaler value will remain unchanged).



The figure below shows some examples of the counter behavior and the update flags for different division factors in the up-counting mode.

| Internal clock              |                              |                                    |
|-----------------------------|------------------------------|------------------------------------|
| divided by 2                | CNTEN                        |                                    |
|                             | CK_PSC                       |                                    |
|                             | Timer clock = CK_CNT         |                                    |
|                             | Counter register             | 0034 0035 0036 0000 0001 0002 0003 |
|                             | Counter overflow             | <sup>′</sup>                       |
|                             | Update interrupt flag(UDITF) |                                    |
|                             | Update event(UEV)            |                                    |
|                             |                              |                                    |
|                             |                              |                                    |
| Internal clock divided by N | CK_PSC                       |                                    |
|                             | Timer clock = CK_CNT         |                                    |
|                             | Counter register             |                                    |
|                             | Counter overflow             |                                    |
|                             | Update interrupt flag(UDITF) |                                    |
|                             | Update event(UEV)            |                                    |
|                             |                              |                                    |

#### Figure 10-3 Timing diagram of up-counting. The internal clock divider factor = 2/N



| ARPEN = 0 <sub>CNTEN</sub>                      |                                                          |  |  |  |  |  |  |
|-------------------------------------------------|----------------------------------------------------------|--|--|--|--|--|--|
| CK_PSC                                          |                                                          |  |  |  |  |  |  |
| _                                               |                                                          |  |  |  |  |  |  |
| Timer clock = CK_CNT                            |                                                          |  |  |  |  |  |  |
| Counter register                                | 31 32 33 34 35 36 00 01 02 03 04 05 06 07                |  |  |  |  |  |  |
| Counter overflow                                |                                                          |  |  |  |  |  |  |
| Update event (UEV)                              |                                                          |  |  |  |  |  |  |
| Update interrupt flag(UDITF)                    |                                                          |  |  |  |  |  |  |
| Auto-reload preload register                    | FF 36                                                    |  |  |  |  |  |  |
| Change AR value<br>Write a new value in TIMx_AR |                                                          |  |  |  |  |  |  |
| ARPEN = 1                                       |                                                          |  |  |  |  |  |  |
| CNTEN                                           |                                                          |  |  |  |  |  |  |
| CK_PSC                                          |                                                          |  |  |  |  |  |  |
| Timer clock = CK_CNT                            |                                                          |  |  |  |  |  |  |
| Counter register                                | F0 \F1 \F2 \F3 \F4 \F5 \00 \01 \02 \03 \04 \05 \06 \07 \ |  |  |  |  |  |  |
| Counter overflow                                |                                                          |  |  |  |  |  |  |
| Update event (UEV)                              |                                                          |  |  |  |  |  |  |
| Update interrupt flag(UDITF)                    |                                                          |  |  |  |  |  |  |
| Auto-reload preload register                    | F5 36                                                    |  |  |  |  |  |  |
| Write a new                                     | value in TIMx_AR                                         |  |  |  |  |  |  |
| -<br>Auto-reload shadow register<br>-           | F5 36                                                    |  |  |  |  |  |  |

Figure 10-4 Timing diagram of the up-counting, update event when ARPEN=0/1



## 10.3.3 Clock selection

■ The internal clock of timers: CK\_INT

### 10.3.3.1 Internal clock source (CK\_INT)

It is provided that the TIMx\_CTRL1.CNTEN bit is written as' 1 ' by software, the clock source of the prescaler is provided by the internal clock CK\_INT.



#### Figure 10-5 Control circuit in normal mode, internal clock divided by 1

## 10.3.4 **Debug mode**

When the microcontroller is in debug mode (the Cortex-M0 core halted), depending on the DBG\_CTRL.TIM6STP configuration in the PWR module, the TIM6 counter can either continue to work normally or stop. For more details, see section 3.4.9.

## 10.4 TIMx register(x=6)

For abbreviations used in registers, see section 1.1

These peripheral registers can be operated as half word (16-bits) or word (32-bits).



## 10.4.1 Register overview

| Offset | Register     | 31<br>30 | 29 | 28 | 27 | 26 | 25 | 24     | 23  | 22 | 21 | 20 | 10       | 18 | 5     | 1/  | 16       | 15 | 14 | 13 | 12 | Ξ | 10 | 6 | ×   | 7      | 9        | 5        | 4 | 3      | 2    | 1      | 0     |
|--------|--------------|----------|----|----|----|----|----|--------|-----|----|----|----|----------|----|-------|-----|----------|----|----|----|----|---|----|---|-----|--------|----------|----------|---|--------|------|--------|-------|
|        | TIMx_CTRL1   |          |    |    |    |    |    |        |     |    |    |    | ved      |    |       |     |          |    |    |    |    |   |    |   |     | ARPEN  |          | ved      |   | ONEPM  | UPRS | UPDIS  | CNTEN |
| 000h   | Deret Malers |          |    |    |    |    |    |        |     |    |    |    | Reserved |    |       |     |          |    |    |    |    |   |    |   |     | 0<br>V |          | Reserved |   | 0<br>0 | 0    | с<br>0 | 0     |
|        | Reset Value  |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     |          |    |    |    |    |   |    |   |     | 0      |          |          |   | 0      | 0    | 0      | 0     |
| 004h   |              |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     |          |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        |       |
| ~      |              |          |    |    |    |    |    |        |     |    |    |    |          | ŀ  | Reser | ved |          |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        |       |
| 008h   |              |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     |          |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        |       |
| 00Ch   | TIMx_DINTEN  |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     | Reserved |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        | UIEN  |
|        | Reset Value  |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     | H        |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        | 0     |
|        |              |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     |          |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        | ſT.   |
| 010h   | TIMx_STS     |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     | Reserved |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        | UDITF |
|        | Reset Value  |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     | H        |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        | 0     |
| 014h   | TIMx_EVTGEN  |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     | Reserved |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        | UDGN  |
|        | Reset Value  |          |    |    |    |    |    |        |     |    |    |    |          |    |       | 1   | Re       |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        | 0     |
|        |              |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     |          |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        |       |
| 018h   |              |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     |          |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        |       |
| ~      |              |          |    |    |    |    |    |        |     |    |    |    |          | ł  | Reser | ved |          |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        |       |
| 020hh  |              |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     |          |    |    |    |    |   |    |   |     |        |          |          |   |        |      |        |       |
|        | TIMx_CNT     |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     |          |    |    |    |    |   |    |   | CNT | [15:0] |          |          |   |        |      |        |       |
| 024h   | Reset Value  |          |    |    |    |    | ŀ  | leserv | /ed |    |    |    |          |    |       |     |          | 0  | 0  | 0  | 0  | 0 | 0  | 0 | 0   | 0      | 0        | 0        | 0 | 0      | 0    | 0      | 0     |
|        | TIMx_PSC     |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     |          |    |    |    |    | 1 |    |   | PSC | 15:0]  | <u> </u> |          |   |        |      |        |       |
| 028h   | Reset Value  |          |    |    |    |    | F  | leserv | /ed |    |    |    |          |    |       |     |          | 0  | 0  | 0  | 0  | 0 | 0  | 0 | 0   | 0      | 0        | 0        | 0 | 0      | 0    | 0      | 0     |
|        | TIMx_AR      |          |    |    |    |    |    |        |     |    |    |    |          |    |       |     |          |    |    | I  |    | 1 | 1  |   | AR[ | 15:0]  |          | 1        |   |        |      |        |       |
| 02Ch   | Reset Value  |          |    |    |    |    | F  | leserv | /ed |    |    |    |          |    |       |     |          | 1  | 1  | 1  | 1  | 1 | 1  | 1 | 1   | 1      | 1        | 1        | 1 | 1      | 1    | 1      | 1     |

Table 10-1 Register overview

## 10.4.2 Control Register 1 (TIMx\_CTRL1)

#### Offset address: 0x00

Reset value: 0x0000



| Bit field | Name     | Description                                  |
|-----------|----------|----------------------------------------------|
| 15:8      | Reserved | Reserved, the reset value must be maintained |
| 7         | ARPEN    | ARPEN: Auto-reload preload enable            |

217 / 319



| Bit field | Name     | Description                                                                                     |
|-----------|----------|-------------------------------------------------------------------------------------------------|
|           |          | 0: Shadow register disable for TIMx_AR register                                                 |
|           |          | 1: Shadow register enable for TIMx_AR register                                                  |
| 6:4       | Reserved | Reserved, the reset value must be maintained                                                    |
| 3         | ONEPM    | One-pulse mode                                                                                  |
|           |          | 0: Disable one-pulse mode, the counter counts are not affected when an update event occurs.     |
|           |          | 1: Enable one-pulse mode, the counter stops counting when the next update event occurs          |
|           |          | (clearing TIMx_CTRL1.CNTEN bit)                                                                 |
| 2         | UPRS     | Update request source                                                                           |
|           |          | This bit is used to select the UEV event sources by software.                                   |
|           |          | 0: If update interrupt request is enabled, any of the following events will generate an update  |
|           |          | interrupt request:                                                                              |
|           |          | Counter overflow                                                                                |
|           |          | The TIMx_EVTGEN.UDGN bit is set                                                                 |
|           |          | 1: If update interrupt request is enabled, only counter overflow will generate update interrupt |
|           |          | request                                                                                         |
| 1         | UPDIS    | Update disable                                                                                  |
|           |          | This bit is used to enable/disable the Update event (UEV) events generation by software.        |
|           |          | 0: Enable UEV. UEV will be generated if one of following condition been fulfilled:              |
|           |          | Counter overflow                                                                                |
|           |          | The TIMx_EVTGEN.UDGN bit is set                                                                 |
|           |          | Shadow registers will update with preload value.                                                |
|           |          | 1: UEV disabled. No update event is generated, and the shadow registers (AR, PSC) keep their    |
|           |          | values. If the TIMx_EVTGEN.UDGN bit is set, the counter and prescaler are reinitialized.        |
| 0         | CNTEN    | Counter Enable                                                                                  |
|           |          | 0: Disable counter                                                                              |
|           |          | 1: Enable counter                                                                               |

## 10.4.3 Interrupt Enable Registers (TIMx\_DINTEN)

Offset address: 0x0C

Reset value: 0x0000

| 15 |   |   |   |   |          |     |       |   |   | 1 | 0    |
|----|---|---|---|---|----------|-----|-------|---|---|---|------|
|    | 1 | 1 | 1 | 1 | 1        |     | 1     | 1 | 1 | 1 |      |
|    |   |   |   |   | Reserved |     |       |   |   |   | UIEN |
| I  |   |   |   |   | <br>     | I I | <br>1 | I |   |   |      |
|    |   |   |   |   |          |     |       |   |   |   | rw   |

| Bit field | Name     | Description                                  |
|-----------|----------|----------------------------------------------|
| 15:1      | Reserved | Reserved, the reset value must be maintained |
| 0         | UIEN     | Update interrupt enable                      |
|           |          | 0: Disable update interrupt                  |
|           |          | 1: Enables update interrupt                  |



## 10.4.4 Status Registers (TIMx\_STS)

Offset address: 0x10

Reset value: 0x0000

| 15 |  |  |  |          |  |  |  | 1 | 0     |
|----|--|--|--|----------|--|--|--|---|-------|
|    |  |  |  | Reserved |  |  |  |   | UDITF |
|    |  |  |  |          |  |  |  |   | rc_w0 |

| Bit field | Name     | Description                                                                             |
|-----------|----------|-----------------------------------------------------------------------------------------|
| 15:1      | Reserved | Reserved, the reset value must be maintained                                            |
| 0         | UDITF    | Update interrupt flag                                                                   |
|           |          | This bit is set by hardware when an update event occurs under the following conditions: |
|           |          | -When TIMx_CTRL1.UPDIS = 0, and counter value overflow.                                 |
|           |          | -When TIMx_CTRL1.UPDIS = 0 and TIMx_CTRL1.UPRS = 0, and set the                         |
|           |          | TIMx_EVTGEN.UDGN bit by software to reinitialize the CNT.                               |
|           |          | This bit is cleared by software.                                                        |
|           |          | 0: No update event occurred                                                             |
|           |          | 1: Update interrupt occurred                                                            |

### 10.4.5 Event Generation registers (TIMx\_EVTGEN)

Offset address: 0x14

Reset values: 0 x0000

|   | 15 |   |   |   |  |   |          |  |  |  | 1 | 0    |
|---|----|---|---|---|--|---|----------|--|--|--|---|------|
|   |    | 1 | 1 | 1 |  | 1 | Reserved |  |  |  |   | UDGN |
| L |    |   |   |   |  |   |          |  |  |  |   | w    |

| Bit field | Name     | Description                                                                                      |
|-----------|----------|--------------------------------------------------------------------------------------------------|
| 15:1      | Reserved | Reserved, the reset value must be maintained.                                                    |
| 0         | UDGN     | Update generation                                                                                |
|           |          | Software can set this bit to update configuration register value and hardware will clear it      |
|           |          | automatically.                                                                                   |
|           |          | 0: No effect.                                                                                    |
|           |          | 1: Timer counter will restart and all shadow register will be updated. It will restart prescaler |
|           |          | counter also.                                                                                    |

## 10.4.6 Counters (TIMx\_CNT)

Offset address: 0x24

Reset value: 0x0000



| 15 |   |  |   |   |   |      |       |  |   |   | 0 |
|----|---|--|---|---|---|------|-------|--|---|---|---|
|    | 1 |  | 1 |   | 1 |      |       |  | 1 | 1 |   |
|    |   |  |   |   |   | CNT[ | 15:0] |  |   |   |   |
|    | I |  |   | 1 | 1 |      |       |  | 1 | 1 |   |

rw

| Bit field | Name      | Description                                                                         |
|-----------|-----------|-------------------------------------------------------------------------------------|
| 15:0      | CNT[15:0] | Counter value                                                                       |
|           |           | Note: When the clock source is configured for LSI, TIMx_CNT does not support writes |

## 10.4.7 Prescaler (TIMx\_PSC)

Offset address: 0x28

#### Reset value: 0x0000

| 15 |   |   |   |   |   |      |        |   |   |   |   |   | 0 |
|----|---|---|---|---|---|------|--------|---|---|---|---|---|---|
|    | 1 | 1 | 1 | 1 |   | DOOL | 15.01  | 1 |   |   | 1 |   | - |
|    |   |   |   |   |   | PSC[ | [15:0] |   |   |   |   |   |   |
|    | 1 | 1 | 1 | 1 | 1 |      | 1      |   | 1 | 1 | 1 | 1 | 1 |

#### rw

| Bit field | Name      | Description                                                                                       |
|-----------|-----------|---------------------------------------------------------------------------------------------------|
| 15:0      | PSC[15:0] | Prescaler value                                                                                   |
|           |           | PSC register value will be updated to prescaler register at update event. Counter clock frequency |
|           |           | is input clock frequency divide PSC + 1.                                                          |

## 10.4.8 Automatic reload register (TIMx\_AR)

#### Offset address: 0x2C

Reset values: 0xFFFF

| 15 |     |   |  |   |       |       |   |    |   |   | 0 |
|----|-----|---|--|---|-------|-------|---|----|---|---|---|
| (  | · · | 1 |  |   | A.D.[ | 15:0] | 1 |    | I | I |   |
|    |     |   |  | 1 | AK    | 15:0] |   | i. | , |   |   |
|    |     |   |  |   | r     | w     |   |    |   |   |   |

| Bit field | Name     | Description                                                                           |
|-----------|----------|---------------------------------------------------------------------------------------|
| 15:0      | AR[15:0] | Auto-reload value                                                                     |
|           |          | These bits define the value that will be loaded into the actual auto-reload register. |
|           |          | See 10.3.1 for more details.                                                          |
|           |          | When the TIMx_AR.AR [15:0] value is null, the counter does not work.                  |



## 11 Independent watchdog (IWDG)

## **11.1 IWDG introduction**

The N32G003 has built-in independent watchdog (IWDG) timers to solve the problems caused by software errors. Watchdog timer is very flexible to use, which improves the security of the system and the accuracy of timing control.

Independent Watchdog (IWDG) is driving by Low-speed internal clock (LSI clock) running at 32 KHz, which will still running event dead loop or MCU stuck is happening. This can provide higher safety level, timing accuracy and flexibility of watchdog. It can reset and resolve system malfunctions due to software failure. The IWDG is best suited for applications that require the watchdog to run as a totally independent process outside the main application, but have lower timing accuracy constraints.

When the power control register PWR\_CTRL.IWDGRSTEN bit is '1' and the IWDG counter reaches 0, a system reset will be generated (if this bit is '0', the IWDG will count but not reset). IWDG reset can also be used for low power wake up.

*Note: This chapter is based on the system default value PWR\_CTRL.IWDGRSTEN = 1.* 

## **11.2 IWDG main features**

- A 12-bit decrement counter that runs independently
- The initial count value of the decrementing counter can be configured, and the pre-frequency can be configured
- After the watchdog is enabled, a system reset occurs when the decrement counter reaches 0x000
- Reset enable is configurable
- Support software/hardware startup
- Can choose to stop counting or work normally in debug mode
- Support low power consumption mode: you can choose to work or freeze in stop mode



## 11.3 IWDG function description



Figure 11-1 Functional block diagram of the independent watchdog module

To enable IWDG, we need to write 0xCCCC to IWDG\_KEY.KEYV[15:0] bits. Counter starts counting down from reset value (0xFFF). When counter count to 0x000, it generates a reset signal (IWDG\_RESET) to MCU. Write 0xDDDD to IWDG\_FREEZE enable the IWDG freeze function, the freeze function can be configured to make the IWDG counter work or stop in STOP mode. Other than that, as long as 0xAAAA (reload request) is write to IWDG\_KEY.KEYV[15:0] bits before reset, the counter value is set to the reload value in the IWDG\_RELV.REL[11:0] bits and prevents the watchdog from resetting the entire device.

If the "hardware watchdog timer" function is enabled through the option byte, the watchdog will automatically start running after the system is powered on and will generate a system reset, unless the software reloads the counter before it reaches '0'.

#### 11.3.1 Register access protection

IWDG\_PREDIV and IWDG\_RELV register are write protected. To modify the value of those two register, user needs to write 0x5555 to IWDG\_KEY.KEYV[15:0] bits. Writing other value enables write protections again. IWDG\_STS.PVU indicates whether the pre-scaler value update is on going. IWDG\_STS.CRVU indicates whether the IWDG is updating the reload value. The hardware sets the IWDG\_STS.PVU bit and/or IWDG\_STS.CRVU bit when the pre-scaler value and/or reload value is updating. After the pre-scaler value and/or reload value update is complete, the hardware clears the IWDG\_STS.PVU bit and/or IWDG\_STS.CRVU bit.

The reload operation (IWDG\_KEY.KEYV[15:0] configured with value of 0xAAAA) will also cause the registers to

222 / 319



become write protected again.

#### 11.3.2 **Debug mode**

In debug mode (Cortex-M0 core stops), IWDG counter will either continue to work normally or stops, depending on DBG\_CTRL.IWDG\_STOP bit in PWR module. If this bit is set to '1', the counter stops. The counter works normally when the bit is '0'. For details, see 3.3.2 Peripheral Debugging Support.

#### 11.3.3 Low power consumption

The working clock of IWDG can be controlled by configuring the IWDG\_FREEZE register to ensure the IWDG is suspended in the stop mode. See the chapter IWDG Freeze register for details 11.5.6.

### **11.4 User Interface**

IWDG module user interface contains 5 registers: Key Register (IWDG\_KEY), Pre-scale Register (IWDG\_PREDIV), Reload Register (IWDG\_RELV), Freeze Register(IWDG\_FREEZE) and Status Register (IWDG\_STS).

#### 11.4.1 Operate Flow

When IWDG is enable from reset from software (write 0xAAAA to IWDG\_KEY.KEYV[15:0] bits) or hardware (clear FLASH\_OB.WDG\_SW bit). It starts counting down from 0xFFF. Down counting gap is determined by prescale LSI clock. Once the counter is reloaded, each new round will start from the value in IWDG\_RELV.REL[11:0] instead of 0xFFF.

When program is running normally, software needs to feed IWDG before counter reaches 0x000 and start a new round of down counting. When counter reach 0x000, this indicates program malfunction. IWDG generates reset signal under this circumstance.

If user wants to configure IWDG pre-scale and reload value register, it needs to write 0x5555 to IWDG\_KEY.KEYV[15:0] first. Then confirm IWDG\_STS.CRVU bit and IWDG\_STS.PVU bit. IWDG\_STS.CRVU bit indicates reload value update is ongoing, IWDG\_STS.PVU indicates Pre-scale divider ratio is updating. Only when those two bit are 0 then user can update corresponding value. When update is on-going, hardware sets corresponding bit to 1. At this time, reading IWDG\_PREDIV.PD[2:0] or IWDG\_RELV.REL[11:0] is invalid since data needs sync to LSI clock domain. The value read from IWDG\_PREDIV.PD[2:0] or IWDG\_RELV.REL[11:0] will be valid after hardware clears the IWDG\_STS.PVU bit or IWDG\_STS.CRVU bit.

If the application uses more than one reload value or pre-scaler value, it must wait until the IWDG\_STS.CRVU bit is reset before changing the reload value, the same as changing the pre-scaler value. However, after updating the pre-scale and/or the reload value, it is not necessary to wait until IWDG\_STS.CRVU bit and/or IWDG\_STS.PVU bit are reset before continuing code execution (even in case of low-power mode entry, the write operation is taken into account and will complete).

Pre-scale register and reload register controls the time that generates reset, as shown in Table 13 1.



#### Table 11-1 IWDG overtime time at 32kHz

| Prescaler<br>divider | IWDG_PREDIV [2:0] | Min timeout (ms)<br>(IWDG_PELV11:0]=0) | Max timeout (ms)<br>(IWDG_PELV[11:0]=0xFFF) |
|----------------------|-------------------|----------------------------------------|---------------------------------------------|
| /4                   | 000               | 0.125                                  | 512                                         |
| /8                   | 001               | 0.25                                   | 1024                                        |
| /16                  | 010               | 0.5                                    | 2048                                        |
| /32                  | 011               | 1                                      | 4096                                        |
| /64                  | 100               | 2                                      | 8192                                        |
| /128                 | 101               | 4                                      | 16384                                       |
| /256                 | 11x               | 8                                      | 32768                                       |

#### 11.4.2 IWDG configuration flow

Software flow:

- 1. Write 0x5555 to IWDG\_KEY.KEYV[15:0] bits to enable write access of IWDG\_PREDIV and IWDG\_RELV registers.
- 2. Check IWDG\_STS.PVU bit and IWDG\_STS.CRVU bit, if they are 0, continue next step.
- 3. Configure IWDG\_PREDIV.PD[2:0] bits to select pre-scale value.
- 4. Configure IWDG\_RELV.REL[11:0] bits reload value.
- 5. Writing 0xAAAA to IWDG\_KEY.KEYV[15:0] bits to upload counter with reload value.
- 6. Configure the IWDG\_FREEZE register
- 7. Write 0xCCCC to IWDG\_KEY.KEYV[15:0] bits to start the watchdog

If you need to modify the prescaler value and reload value, repeat steps 1 to 5; if you don't need to reconfigure, just perform step 5 to feed the dog at regular intervals.

### **11.5 IWDG registers**

### 11.5.1 IWDG register map

#### 24 23 22 20 19 1817 16 15 4 12 10 Offse Register 31 8 29 28 27 26 25 21 13 Ξ 6 9 0 × ~ ŝ ŝ 0 IWDG\_KEY KEYV[15:0] 0001 Reserved Reset Value 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 IWDG\_PREDIV PD[2:0] 004ŀ Reserved Reset Value 0 0 0 IWDG\_RELV REL[11:0] 0081 Reserved 1 Reset Value 1 1 1 1 1 1 1 1 1 1 CRVU PVU IWDG\_STS 00Ch Reserved

#### Table 11-2 IWDG register map and reset values

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| Offse | Register    | 31<br>30<br>30<br>30<br>28<br>28<br>26<br>26<br>25<br>22<br>22<br>22<br>22<br>22<br>22<br>17<br>17<br>17<br>17<br>18<br>18<br>18<br>18<br>18<br>18<br>11<br>11<br>11<br>11<br>12<br>13<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3 | 1 | 0      |
|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|
|       | Reset Value |                                                                                                                                                                                                                                               | 0 | 0      |
| 010h  | IWDG_FREEZE | Reserved                                                                                                                                                                                                                                      |   | FREEZE |
|       | Reset Value |                                                                                                                                                                                                                                               |   | 0      |

#### 11.5.2 IWDG Key register (IWDG\_KEY)

#### Address offset: 0x00

Reset value: 0x0000 0000

| 31 |   |   |   |   | <br> |      |        | <br> |   |   |   |   | 16 |
|----|---|---|---|---|------|------|--------|------|---|---|---|---|----|
|    |   |   |   |   |      | Rese | erved  |      |   |   |   |   |    |
|    | 1 | 1 | 1 | 1 |      |      |        |      | 1 |   | 1 | 1 |    |
| 15 |   | - |   |   |      |      |        |      |   | - |   | • | 0  |
|    |   |   |   |   |      | KEYV | [15:0] |      |   |   |   |   |    |
|    |   |   |   |   |      | rc_  | w0     |      |   |   |   |   |    |

| Bit Field | Name       | Description                                                                              |
|-----------|------------|------------------------------------------------------------------------------------------|
| 31:16     | Reserved   | Reserved, the reset value must be maintained.                                            |
| 15:0      | KEYV[15:0] | Key value register: only certain value will serve particular function.                   |
|           |            | <b>0xCCCC:</b> Start watch dog counter, does not have any effect if hardware watchdog is |
|           |            | enable, (if hardware watchdog is selected, it is not limited by this command word)       |
|           |            | <b>0xAAAA:</b> Reload counter with REL value in IWDG_RELV register to prevent reset.     |
|           |            | 0x5555: Disable write protection of IWDG_PREDIV and IWDG_RELV register                   |

#### 11.5.3 IWDG Pre-Scaler register (IWDG\_PREDIV)

Address offset: 0x04



| Bit Field | Name     | Description                                                                          |
|-----------|----------|--------------------------------------------------------------------------------------|
| 31:3      | Reserved | Reserved, the reset value must be maintained.                                        |
| 2:0       | PD[2:0]  | Pre-frequency division factor                                                        |
|           |          | With write access protection when IWDG_KEY.KEYV[15:0] is not 0x5555. The             |
|           |          | IWDG_STS.PVU bit must be 0 otherwise PD [2:0] value cannot be changed. Divide number |
|           |          | is as follow:                                                                        |
|           |          | 000: Prescaler divider =4                                                            |
|           |          | 001: Prescaler divider =8                                                            |



|  | 010: Prescaler divider =16                                                                   |
|--|----------------------------------------------------------------------------------------------|
|  | 011: Prescaler divider =32                                                                   |
|  | 100: Prescaler divider =64                                                                   |
|  | 101: Prescaler divider =128                                                                  |
|  | 11x: Prescaler divider =256                                                                  |
|  | Note: Reading this register will return the pre-divided value from the VDD voltage domain.   |
|  | If a write operation is in progress, the read-back value may be invalid. Therefore, the read |
|  | value is valid only when the IWDG_STS.PVU bit is '0'.                                        |

#### 11.5.4 IWDG Reload register (IWDG\_RELV)

Address offset: 0x08

Reset value: 0x0000 0FFF



| Bit Field | Name      | Description                                                                                   |
|-----------|-----------|-----------------------------------------------------------------------------------------------|
| 31:12     | Reserved  | Reserved, the reset value must be maintained.                                                 |
| 11:0      | REL[11:0] | Watchdog counter reload value.                                                                |
|           |           | With write protection. Defines the reload value of the watchdog counter, which is loaded to   |
|           |           | the counter every time 0xAAAA is written to IWDG_KEY.KEYV[15:0] bits. The counter             |
|           |           | then starts to count down from this value. The watchdog timeout period can be calculated      |
|           |           | from this reloading value and the clock pre-scaler value, refer to Table 11-1.                |
|           |           | This register can only be modified when the IWDG_STS.CRVU bit is '0'.                         |
|           |           | Note: Reading this register will return the reload value from the VDD voltage domain. If a    |
|           |           | write operation is in progress, the read-back value may be invalid. Therefore, the read value |
|           |           | is valid only when the IWDG_STS.CRVU bit is '0'.                                              |

## 11.5.5 IWDG Status register (IWDG\_STS)

Address offset: 0x0C





-

| Bit Field | Name     | Description                                                                                  |
|-----------|----------|----------------------------------------------------------------------------------------------|
| 31:2      | Reserved | Reserved, the reset value must be maintained.                                                |
| 1         | CRVU     | Watchdog reload value update                                                                 |
|           |          | Reload Value Update: this bit indicates an update of reload value is ongoing. Set by         |
|           |          | hardware and clear by hardware(up to 5 RC cycles of 32kHz) .Software can only try to         |
|           |          | change IWDG_RELV.REL[11:0] value when IWDG_KEY.KEYV[15:0] bits' value is                     |
|           |          | 0x5555 and this bit is 0.                                                                    |
| 0         | PVU      | Watchdog prescaler value update                                                              |
|           |          | Pre-scaler Value Update: this bit indicates an update of pre-scaler value is ongoing. Set by |
|           |          | hardware and clear by hardware(up to 5 RC cycles of 32kHz). Software can only try to         |
|           |          | change IWDG_PREDIV.PD[2:0] value when IWDG_KEY.KEYV[15:0] bits' value is                     |
|           |          | 0x5555 and this bit is 0.                                                                    |

### 11.5.6 IWDG Freeze register (IWDG\_FREEZE)

Address offset: 0x010

| 31 |   |   |   |   |     |              |      |   |   |     |     | 16          |
|----|---|---|---|---|-----|--------------|------|---|---|-----|-----|-------------|
|    | 1 | 1 | 1 | 1 |     | Rese         | rved | 1 | 1 |     |     |             |
|    | 1 | 1 | 1 | 1 | L I | 1            | 1    | 1 | 1 | 1   | 1   | I]          |
| 15 |   |   |   |   |     |              |      |   |   |     |     |             |
|    |   |   |   |   |     |              |      |   |   |     | 1   |             |
|    |   | 1 |   |   |     | <br>Reserved |      | 1 | i | i . | - 1 | 0<br>FREEZE |

| Bit Field | Name     | Description                                                                       |
|-----------|----------|-----------------------------------------------------------------------------------|
| 31:1      | Reserved | Reserved, the reset value must be maintained.                                     |
| 0         | FREEZE   | STOP mode freeze function                                                         |
|           |          | 1. The initial value of IWDG_FREEZE.FREEZE bit is 0x00;                           |
|           |          | 2. When writing 0xDDDD to this address, IWDG_FREEZE.FREEZE flips once and         |
|           |          | becomes 1, and controls counter stops after entering STOP mode.                   |
|           |          | 3. When 0xDDDD is written to the address again, IWDG_FREEZE.FREEZE flips once and |
|           |          | becomes 0, and controls counter continues to count after entering STOP mode.      |
|           |          | 4. And so on                                                                      |
|           |          | The current value of IWDG_FREEZE.FREEZE can be determined by reading the freeze   |
|           |          | register firstly, and then the switch freeze operation can be performed.          |



## 12 Analog to digital conversion (ADC)

### **12.1 ADC introduction**

The 12-bit ADC is a high-speed analog-to-digital converter using successive approximation. It can measure 10 channel signal source. It has 9 external and 1 internal channel. Each channel of the A/D conversion performed in single, continuous or scan mode. ADC measurements are stored (left-aligned/ right-aligned) in 16-bit data registers. The application can detect that the input voltage is within user-defined high/low thresholds by analog watchdog and the maximum frequency of the input clock to the ADC is 24MHz.

### **12.2** Main Features

- Supports 1 ADC, supports single-ended inputs, and can measure 9 external and 1 internal sources
- Supports 12-bit resolution with a maximum sampling rate of 1MSPS
- ADC clock source is divided into working clock source and timing clock source
  - ♦ HSI as the ADC\_CLK working clock source, up to 24M.
  - HSI as the ADC\_1MCLK timing clock source for internal timing functions, the frequency must be configured to 1MHz.
- Supports timer trigger ADC sampling
- Interrupts when conversion ends, and simulated watchdog events occur
- Support 2 conversion modes
  - Single conversion
  - Continuous conversion
- Scan mode supports up to any 5 channels, each channel has an independent result data register buffer
- All channel sampling intervals can be programmed uniformly
- Regular conversion has external triggering options
- ADC power supply requirements: 2.4V to 5.5V
- ADC input range:  $0 \le V_{IN} \le V_{DD}$

### **12.3 ADC function description**

Below is a block diagram of an ADC module. Table 12-1 shows the description of ADC pins.



#### Figure 12-1 Block diagram of ADC



#### Table 12-1 ADC pins

| Name            | Signal types                      | Annotations                                                                 |
|-----------------|-----------------------------------|-----------------------------------------------------------------------------|
| V <sub>DD</sub> | Input, analog power supply        | Equivalent to $V_{DD}$ analog power supply and: $2V \leq V_{DD} \leq 5.5~V$ |
| V <sub>SS</sub> | Input, analog power supply ground | Equivalent to Vss analog power supply ground                                |
| ADCx_IN[8:0]    | Analog input signal               | 9 analog external input channels                                            |



#### 12.3.1 ADC clock

An ADC requires three clocks, ADC\_CLK, HCLK, and ADC\_1MCLK.

- HCLK is used for the register access.
- ADC\_CLK is the working clock of ADC.
- ADC\_1MCLK for internal timing function, configured in RCC, frequency size must be configured to 1M

Note:

1. The ADC\_CLK frequency division can be configured as a working clock up to 24MHz. The ADC\_CLK frequency division can be 1,2,3,4,6,8,10,12,24,32

#### 12.3.2 ADC switch control

You can proceed to the next step only after the power-up process is complete. You can check if the power-up is complete by polling the ADC\_CTRL3.RDY bit.

You can set the ADC\_CTRL2.ON bit to turn on the ADC. When the ADC\_CTRL2.ON bit is set for the first time, it wakes up the ADC from the power-off state. After a power-on delay of ADC (t<sub>STAB</sub>), and the conversion begins when the ADC\_CTRL2.ON bit is set again.

The conversion can be stopped by clearing the ADC\_CTRL2.ON bit and placing the ADC in power-off mode. In this mode, the ADC consumes almost no power (just a few  $\mu$ A). Power-down can be checked by polling the ADC\_CTRL3.PDRDY bit.

When the ADC is disabled, the default mode is power-down.

#### 12.3.3 Channel selection

Each channel can be configured as a regular sequence. A series of conversions in any order on any number of channels. For example, the conversion can be completed in the following order: channel 3, channel 8, channel 2, channel 1, channel 0.

Regular sequence consists of multiple conversions, up to a maximum of 5. The ADC\_DATx.SEQx[3:0] registers bits specify the regular channels and their conversion. The ADC\_CTRL2.LEN[2:0] bits specified the regular channel sequence length.

*Note:* During conversion, changes to the ADC\_DATx.SEQx[3:0] are prohibited; the ADC\_DATx.SEQx[3:0] registers can only be changed when the ADC is idle.

#### 12.3.4 Internal channel

The VREFINT is connected with channel ADC\_IN9.

Internal channels can be converted by regular channels.



#### 12.3.5 Single conversion mode

The ADC can enter the single conversion mode by configuring ADC\_CTRL2.CTU to 0. In this mode, external triggering or setting ADC\_CTRL2.ON=1 can start the ADC to start conversion, and the ADC only performs one conversion.

After the conversion starts, when a regular channel conversion is completed, the regular channel conversion end flag(ADC\_STS.ENDC) will be set to 1. If the regular channel conversion end interrupt enable (ADC\_CTRL1.ENDCIEN) bit is set to 1, an interrupt will be generated at this time, and the converted data will be stored in the ADC\_DATx.DAT[15:0] register.

After single conversion, the ADC stops.

#### 12.3.6 Continuous conversion mode

The ADC can enter the continuous conversion mode by configuring ADC\_CTRL2. CTU to 1. In this mode, external triggering or setting ADC\_CTRL2.ON to 1 can start the ADC to start conversion, and the ADC will continuously convert the selected channel.

After the conversion starts, when a regular channel conversion is completed, the regular channel end of conversion flag bit (ADC\_STS.ENDC) will be set to 1. If the regular channel conversion end interrupt enable bit (ADC\_CTRL1.ENDCIEN) is set to 1 at this time, an interrupt will be generated. The converted data will be stored in the ADC\_DATx.DAT[15:0] register.

#### 12.3.7 **Timing diagram**

When ADC\_CTRL2.ON is set to 1 for the first time, the ADC is powered on. After the ADC is powered on, the ADC needs a certain time(tSTAB) to ensure its stability. After the ADC is stabilized, ADC\_CTRL2.ON is set to 1. At this time, set ADC\_CTRL2.ON to 1 again through software. To start the conversion and after 24 cycles, the end of conversion flag bit will be set to 1 after the conversion is completed.







#### 12.3.8 Analog watchdog

The analog watchdog can be enabled on the regular channel by setting ADC\_CTRL1.AWDGERCH to 1. The high threshold of the analog watchdog can be set by configuring ADC\_WDGHIGH.HTH, and the low threshold of the analog watchdog can be set by configuring ADC\_WDGLOW.LTH. The threshold of the analog watchdog has nothing to do with the way of data alignment, because the comparison of the ADC's conversion value with the threshold is done before the alignment. When the value of ADC analog conversion is higher than the high threshold of the analog watchdog or lower than the low threshold of the analog watchdog, the analog watchdog flag (ADC\_STS.AWDG) will be set to 1, if ADC\_CTRL1.AWDGIEN has been configured to 1, an interrupt will be generated at this time. The analog watchdog can be controlled for one or more channels by configuring ADC\_CTRL1.AWDSGSGLEN and ADC\_CTRL1.AWDGCH[3:0].

| Table 12-2 Analog watchdog | channel selection |
|----------------------------|-------------------|
|----------------------------|-------------------|

| Channel                | ADC_CTRL1 regi | ister control bit |
|------------------------|----------------|-------------------|
| Channel                | AWDGSGLEN      | AWDGERCH          |
| All regular channels   | 0              | 1                 |
| Single regular channel | 1              | 1                 |

#### 12.3.9 **Scan mode**

By configuring ADC\_CTRL1.SCAMD to 1, the scan mode can be turned on, and by configuring the registers ADC\_DATx.SEQx[3:0], the conversion sequence can be selected, and the ADC will scan and convert all the selected



channels, each sequence can select any channel for conversion. After the conversion is started, the channels will be converted sequentially one by one, supporting up to 5 conversion sequences. If ADC\_CTRL2.CTU is 1 at this time, the conversion will be restarted from the first channel of the conversion sequence after the conversion of all selected channels is completed.

## 12.4 Data aligned

There are two alignment methods for data storage after conversion: left-aligned and right-aligned. The alignment can be set by the ADC\_CTRL2.ALIG bit. ADC\_CTRL2.ALIG = 0 is right-aligned,  $ADC_CTRL2.ALIG = 1$  is left-aligned, as shown in following tables.

| 0 | 0 | 0 | 0 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|---|---|---|---|-----|-----|----|----|----|----|----|----|----|----|----|----|
|---|---|---|---|-----|-----|----|----|----|----|----|----|----|----|----|----|

Table 12-4 Left-align data

| D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | 0 | 0 | 0 | 0 |
|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|

### 12.5 Programmable channel sampling time

Specify the number of sampling cycles of ADC in ADC\_SAMPT.SAMP[4:0], and then the ADC samples the input voltage in the specified sampling cycle. For different channels, Sampling intervals can be programmed uniformly. The total conversion time is calculated as follows:

 $T_{CONV} =$  Sampling time + 12 cycles

Example:

ADCCLK=24MHz, the sampling time is 12 cycles and resolution is 12bit, the total conversion time is "12 + 12" ADCCLK Cycles, that is:

 $T_{CONV} = 12 + 12 = 24$  cycle = 1µs

Note: All ADC channels share a channel sample time configuration.

### **12.6 Externally triggered conversion**

For the regular sequence, software sets the ADC\_CTRL2.EXTRTRIG bit to 1, then the regular channel can use the rising edge of the external event to trigger the start conversion, and then the software sets the ADC\_CTRL2.EXTRSEL[3:0] bits to select the external trigger source of the regular sequence. The external trigger source selection is shown in the table below. If you select EXTI line as the external trigger source, you can set the AFIO\_CFG.EXTI\_ETRR[4:0] bits to implement; if you select SWSTRRCH as the external trigger source, you can start the regular channel conversion by setting ADC\_CTRL2.SWSTRRCH to 1.

| EXTRSEL[3:0] | Trigger source | Туре                                   |
|--------------|----------------|----------------------------------------|
| 0000         | TIM1_CC1 event | Internal signal from the on-chip timer |



| EXTRSEL[3:0] | Trigger source  | Туре                                            |
|--------------|-----------------|-------------------------------------------------|
| 0001         | TIM1_CC2 event  |                                                 |
| 0010         | TIM1_CC3 event  |                                                 |
| 0011         | TIM1_CC4 event  |                                                 |
| 0100         | TIM1_TRGO event |                                                 |
| 0101         | TIM3_TRGO event |                                                 |
| 0110         | TIM3_CC1 event  |                                                 |
| 0111         | TIM3_CC2 event  |                                                 |
| 1000         | EXTI line event | External pin/internal signal from on-chip timer |
| 1001         | SWSTRRCH        | Software control bit                            |

### **12.7 ADC interrupt**

ADC interrupts can be from an end of regular sequence conversion, an analog watchdog event when input voltage exceeds the threshold, any end of regular channel conversion. These interrupts have independent interrupt enable bits.

There is a status flags in the ADC\_STS register: regular sequence channel conversion started (STR). But there are no interrupts associated with this flag in the ADC.

#### Table 12-6 ADC interrupt

| Interrupt event                             | Event flags | Enable control bit |
|---------------------------------------------|-------------|--------------------|
| Regular sequence conversion is complete     | ENDC        | ENDCIEN            |
| Analog watchdog status bit is set           | AWDG        | AWDGIEN            |
| Any regular channel interruption is enabled | ENDCA       | ENDCAIEN           |

## 12.8 ADC registers

### 12.8.1 ADC registers

| Offset | Register    | 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 00 | 19   | 18       | 17 | 16       | 15 | 14      | 13       | 12        | 11            | 10      | 6 | ~           | 7    | 9  | 5        | 4     | 3     | 2         | -      | 0        |  |
|--------|-------------|----|----------|----|----|----|----|----|----|----|----|----|----|------|----------|----|----------|----|---------|----------|-----------|---------------|---------|---|-------------|------|----|----------|-------|-------|-----------|--------|----------|--|
| 000h   | ADC_STS     |    |          |    |    |    |    |    |    |    |    |    |    |      | Reserve  | ed |          |    |         |          |           |               |         |   |             |      |    |          |       | ENDCA | STR       | ENDC   | AWDG     |  |
|        | Reset Value |    |          |    |    |    |    |    |    |    |    |    |    |      |          |    |          |    |         |          |           |               |         |   |             |      |    |          |       | 0     | 0         | 0      | 0        |  |
| 004h   | ADC_CTRL1   |    | Reserved |    |    |    |    |    |    |    |    |    |    |      |          |    |          |    | TEST_EN | AWDGEN   | AWDGSGLEN | AWDGIEN       | ENDCIEN |   | AWDGCH[3:0] |      |    |          |       |       |           |        |          |  |
|        | Reset Value |    |          |    |    |    |    |    |    |    |    |    |    |      |          |    |          |    |         |          |           |               |         |   | 0           | 0    | 0  | 0        | 0     | 0     | 0         | 0      | 0        |  |
| 008h   | ADC_CTRL2   |    | Reserved |    |    |    |    |    |    |    |    |    |    |      | COV_MODE |    | LEN[2:0] |    | SWSTART | EXTRTRIG |           | EVTDSEI [3.0] |         |   | ALIG        | CONT | NO |          |       |       |           |        |          |  |
|        | Reset Value |    |          |    |    |    |    |    |    |    |    |    |    |      |          |    |          |    |         |          | 0         | 0             | 0       | 0 | 0           | 0    | 0  | 0        | 0     | 0     | 0         | 0      | 0        |  |
| 00Ch   | ADC_CTRL3   |    |          |    |    |    |    |    |    |    |    |    |    | Rese | ved      |    |          |    |         |          |           |               |         |   |             |      |    | ENDCAIEN | PDRDY | RDY   | BUF_READY | BUF_EN | Reserved |  |
|        | Reset Value |    |          |    |    |    |    |    |    |    |    |    |    |      |          |    |          |    |         |          |           |               |         |   |             |      |    | 0        | 1     | 0     | 0         | 0      |          |  |

#### Table 12-7 Register overview

#### Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| Offset | Register        | 31 | 30       | 29       | 28 | 27 | 26   | 25     | 24 | 23          | 22          | 21  | 20 | 19 | 18         | 17         | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 6 | 8    | 7     | 9    | 5     | 4 | 3 | 2         | 1 | 0 |
|--------|-----------------|----|----------|----------|----|----|------|--------|----|-------------|-------------|-----|----|----|------------|------------|----|----|----|----|----|----|----|---|------|-------|------|-------|---|---|-----------|---|---|
| 010h   | ADC_SAMP        |    |          |          |    |    |      |        |    |             |             |     |    | Re | served     |            |    |    |    |    |    |    |    |   |      |       |      |       |   |   | SAMP[4:0] |   |   |
|        | Reset Value     |    |          |          |    |    |      |        |    |             |             |     |    |    |            |            |    |    |    |    |    |    |    |   |      |       |      |       | 0 | 0 | 0         | 0 | 0 |
| 014h   | ADC_WDGHIG<br>H |    |          |          |    |    |      |        |    | R           | leserv      | ved |    |    |            |            |    |    |    |    |    |    |    |   |      | Η     | TH[  | 11:0] |   |   |           |   |   |
|        | Reset Value     |    |          |          |    |    |      |        |    |             |             |     |    |    |            |            |    |    |    |    | 1  | 1  | 1  | 1 |      | 1     | 1    | 1     | 1 | 1 | 1         | 1 | 1 |
| 018h   | ADC_WDGLOW      |    |          |          |    |    |      |        |    | R           | leserv      | ved |    |    |            |            |    |    |    |    |    |    |    |   |      | Ľ     | TH[1 | 1:0]  |   |   |           |   |   |
|        | Reset Value     |    |          |          |    |    |      |        |    |             |             |     |    |    |            |            |    |    |    |    | 0  | 0  | 0  | 0 | ) (  | 0     | 0    | 0     | 0 | 0 | 0         | 0 | 0 |
| 01Ch   | ADC_DAT0        |    | Reserved |          |    |    |      |        |    | SEQ0[19:16] |             |     |    |    | DAT0[15:0] |            |    |    |    |    |    |    |    |   |      |       |      |       |   |   |           |   |   |
| oren   | Reset Value     |    |          |          |    |    | Res  | erveu  |    |             |             |     |    | 0  | 0          | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0    | 0     | 0    | 0     | 0 | 0 | 0 0       | 0 | 0 |
| 020h   | ADC_DAT1        |    |          |          |    |    | Pag  | erved  |    |             |             |     |    |    | SEQ1       | [19:16     | ]  |    |    |    |    |    |    |   | DAT  | 1[15: | 0]   |       |   |   |           |   |   |
| 02011  | Reset Value     |    |          |          |    |    | Res  | erveu  |    |             |             |     |    | 0  | 0          | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0    | 0     | 0    | 0     | 0 | 0 | 0 0       | 0 | 0 |
| 024h   | ADC_DAT2        |    |          |          |    |    | Pas  | erved  |    |             |             |     |    |    | SEQ2       | [19:16     | ]  |    |    |    |    |    |    |   | DAT  | 2[15: | 0]   |       |   |   |           |   |   |
| 0240   | Reset Value     |    |          |          |    |    | Res  | Ji veu |    |             |             |     |    | 0  | 0          | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0    | 0     | 0    | 0     | 0 | C | ) 0       | 0 | 0 |
| 028h   | ADC_DAT3        |    |          |          |    |    | Pas  | erved  |    |             |             |     |    |    | SEQ3       | [19:16     | ]  |    |    |    |    |    |    |   | DAT: | 3[15: | 0]   |       |   |   |           |   |   |
| 02811  | Reset Value     |    |          |          |    |    | Res  | er ved |    |             |             |     |    | 0  | 0          | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0    | 0     | 0    | 0     | 0 | C | 0 0       | 0 | 0 |
| 02Ch   | ADC_DAT4        |    |          | Reserved |    |    |      |        |    |             | SEQ4[19:16] |     |    |    |            | DAT4[15:0] |    |    |    |    |    |    |    |   |      |       |      |       |   |   |           |   |   |
| 02CII  | Reset Value     |    |          |          |    |    | Rest | li veu |    |             |             |     |    | 0  | 0          | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0    | 0     | 0    | 0     | 0 | 0 | 0 0       | 0 | 0 |

## 12.8.2 ADC status register (ADC\_STS)

Address offset: 0x00



| Bit Field | Name     | Description                                                                                     |
|-----------|----------|-------------------------------------------------------------------------------------------------|
| 31:4      | Reserved | Reserved, the reset value must be maintained.                                                   |
| 3         | ENDCA    | Any channel End of conversion Flag                                                              |
|           |          | This bit is set by hardware at the end of regular channel conversion and cleared by software.   |
|           |          | 0: The conversion is not complete;                                                              |
|           |          | 1: The conversion is complete.                                                                  |
| 2         | STR      | Regular channel start flag                                                                      |
|           |          | This bit is set by hardware at the start of regular channel conversion and cleared by software. |
|           |          | 0: Regular channel conversion has not started.                                                  |
|           |          | 1: Regular channel conversion has started.                                                      |
| 1         | ENDC     | End of conversion                                                                               |
|           |          | This bit is set by hardware at the end of channel group conversion and cleared by software      |
|           |          | 0: the conversion is not complete.                                                              |
|           |          | 1: The conversion is complete.                                                                  |



| Bit Field | Name | Description                                                                                       |
|-----------|------|---------------------------------------------------------------------------------------------------|
| 0         | AWDG | Analog watchdog flag                                                                              |
|           |      | This bit is set by hardware and cleared by software when converted voltage values are outside the |
|           |      | range defined by the ADC_WDGHIGH.HTH and ADC_WDGLOW.LTH registers                                 |
|           |      | 0: No simulated watchdog event occurs;                                                            |
|           |      | 1: The simulated watchdog event occurs.                                                           |

## 12.8.3 ADC control register 1 (ADC\_CTRL1)

Address offset: 0x04



| Bit Field | Name        | Description                                                                                    |
|-----------|-------------|------------------------------------------------------------------------------------------------|
| 31:8      | Reserved    | Reserved, the reset value must be maintained.                                                  |
| 7         | AWDGERCH    | Analog watchdog enable on regular channels                                                     |
|           |             | This bit is set and cleared by the software.                                                   |
|           |             | 0: Disables analog watchdog on regular channel.                                                |
|           |             | 1: Use analog watchdog on regular channels.                                                    |
| 6         | AWDGSGLEN   | Enable the watchdog on a single channel in scan mode                                           |
|           |             | This bit is set and cleared by software to enable or disable analog watchdog functions on      |
|           |             | channels specified by ADC_CTRL1.AWDGCH[3:0]                                                    |
|           |             | 0: Use watchdog on all channels.                                                               |
|           |             | 1: Use watchdog on single channel.                                                             |
| 5         | AWDGIEN     | Analog watchdog interrupt enable                                                               |
|           |             | This bit is set and cleared by software to disallow or allow interrupt generated by simulated  |
|           |             | watchdog.In scan mode, if the watchdog detects an out-of-range value, the scan is aborted only |
|           |             | when that bit is set.                                                                          |
|           |             | 0: Disable analog watchdog interruption.                                                       |
|           |             | 1: Enable analog watchdog interruption.                                                        |
| 4         | ENDCIEN     | Interrupt enable for any channels                                                              |
|           |             | This bit is set and cleared by the software to disallow or allow interrupts to occur after the |
|           |             | regular channel conversion ends.                                                               |
|           |             | 0: Disable ENDC interruption.                                                                  |
|           |             | 1: Enable ENDC interruption.                                                                   |
| 3:0       | AWDGCH[3:0] | Analog watchdog channel select bits                                                            |
|           |             | These bits are set and cleared by software. They select the input channel to be guarded by     |



| Bit Field | Name | Description                |
|-----------|------|----------------------------|
|           |      | the analog watchdog.       |
|           |      | 0000: ADC analog Channel0  |
|           |      | 0001: ADC analog Channel1  |
|           |      |                            |
|           |      | 1001: ADC analog Channel9  |
|           |      | Reserved all other values. |

## 12.8.4 ADC control register 2 (ADC\_CTRL2)

Address offset: 0x08



| Bit Field | Name     | Description                                                                                   |
|-----------|----------|-----------------------------------------------------------------------------------------------|
| 31:13     | Reserved | Reserved, the reset value must be maintained.                                                 |
| 12        | SCANMD   | Scan mode                                                                                     |
|           |          | This bit is set and cleared by the software to enable or disable scan mode. In scan mode, the |
|           |          | conversion is made by ADC_DATx.ADC_SEQx[3:0] register.                                        |
|           |          | 0: Disable scan mode.                                                                         |
|           |          | 1: Enable scan mode.                                                                          |
|           |          | Note: If the ADC_CTRL1.ENDCIEN bits are set separately, ADC_STS.ENDC interrupts occur         |
|           |          | only after the last channel has been converted.                                               |
| 11:9      | LEN[2:0] | Channel sequence length                                                                       |
|           |          | These bits are written by software to define the total number of conversions in the           |
|           |          | channel conversion sequence.                                                                  |
|           |          | 000: 1 conversion                                                                             |
|           |          | 001: 2 conversions                                                                            |
|           |          | 010: 3 conversions                                                                            |
|           |          | 011: 4 conversions                                                                            |
|           |          | 100: 5 conversions                                                                            |
| 8         | SWSTRRCH | Start conversion of channels                                                                  |
|           |          | This bit is set by software to start conversion and cleared by hardware as soon as            |
|           |          | conversion starts. It starts a conversion of a group of channels if SWSTRRCH is               |
|           |          | selected as trigger event by the ADC_CTRL2.EXTRSEL[3:0] bits.                                 |
|           |          | 0: Reset state                                                                                |
|           |          | 1: Starts conversion of channels                                                              |



| Bit Field | Name         | Description                                                                                             |
|-----------|--------------|---------------------------------------------------------------------------------------------------------|
| 7         | EXTRTRIG     | External trigger conversion mode for channels                                                           |
|           |              | This bit is set and cleared by software to enable or disable external triggering events that can        |
|           |              | initiate channel group conversion.                                                                      |
|           |              | 0: Start conversion without external events;                                                            |
|           |              | 1: Use an external event to start the conversion.                                                       |
| 6:3       | EXTRSEL[3:0] | External event select for regular sequence                                                              |
|           |              | These bits select external events to start the regular sequence conversion                              |
|           |              | The triggering configuration of ADC is as follows:                                                      |
|           |              | 0000: Timer 1 CC1 event                                                                                 |
|           |              | 0001: Timer 1 CC2 event                                                                                 |
|           |              | 0010: Timer 1 CC3 event                                                                                 |
|           |              | 0011: Timer 1 CC4 event                                                                                 |
|           |              | 0100: Timer 1 TRGO event                                                                                |
|           |              | 0101: Timer 3 TRGO event                                                                                |
|           |              | 0110: Timer 3 CC1 event                                                                                 |
|           |              | 0111: Timer 3 CC2 event                                                                                 |
|           |              | 1000: EXTI line                                                                                         |
|           |              | 1001: SWSTRRCH                                                                                          |
| 2         | ALIG         | Data alignment                                                                                          |
|           |              | This bit is set and cleared by the software.                                                            |
|           |              | 0: Right-aligned;                                                                                       |
|           |              | 1: Left-align.                                                                                          |
| 1         | CTU          | Continuous conversion                                                                                   |
|           |              | This bit is set and cleared by the software. If this bit is set, the conversion continues until the bit |
|           |              | is cleared.                                                                                             |
|           |              | 0: single conversion mode.                                                                              |
|           |              | 1: Continuous conversion mode.                                                                          |
| 0         | ON           | A/D Converter ON/OFF                                                                                    |
|           |              | This bit is set and cleared by the software. When the bit is' 0 ', writing '1' will wake the ADC        |
|           |              | from power-off mode.                                                                                    |
|           |              | When the bit is' 1 ', writing '1' starts the conversion. The application should note that there is a    |
|           |              | delay t between the time the converter is powered on and the time the conversion begins $t_{STAB}$ ,    |
|           |              | see Figure 12-2.                                                                                        |
|           |              | 0: close ADC conversion and enter power off mode;                                                       |
|           |              | 1: Start ADC and start conversion.                                                                      |
|           |              | Note: If there are other bits changed in this register along with ON, the conversion will not be        |
|           |              | triggered. This is to prevent the wrong conversion from being triggered.                                |

## 12.8.5 ADC control register 3 (ADC\_CTRL3)

Address offset: 0x0C



| 31 |   |   |   |      |       |   |      |      |   |              |       |     |             |            | 16       |
|----|---|---|---|------|-------|---|------|------|---|--------------|-------|-----|-------------|------------|----------|
|    |   |   | 1 | 1    | 1     | 1 | Rese | rved |   | 1            | 1     | 1   | 1           |            |          |
| 15 |   | 1 |   |      |       |   |      |      | 6 | 5            | 4     | 3   | 2           | 1          | 0        |
|    | 1 | 1 | 1 | Rese | erved |   | 1    |      |   | ENDC<br>AIEN | PDRDY | RDY | VREF<br>RDY | VREF<br>EN | Reserved |
|    |   |   |   |      |       |   |      |      |   | rw           | r     | r   | r           | rw         |          |

| Bit Field | Name     | Description                                                                                           |
|-----------|----------|-------------------------------------------------------------------------------------------------------|
| 31:6      | Reserved | Reserved, the reset value must be maintained.                                                         |
| 5         | ENDCAIEN | Interrupt enable for any channels                                                                     |
|           |          | This bit is set and cleared by the software to enable/disable channel conversion to end the interrupt |
|           |          | 0: ADC_STS.ENDCA interrupt is disabled                                                                |
|           |          | 1: ADC_STS.ENDCA interrupt is enabled                                                                 |
| 4         | PDRDY    | ADC power down ready                                                                                  |
|           |          | 0: ADC is powered on                                                                                  |
|           |          | 1: ADC is powered down                                                                                |
| 3         | RDY      | ADC Ready                                                                                             |
|           |          | 0: Not ready                                                                                          |
|           |          | 1: Get ready                                                                                          |
| 2         | VREFRDY  | VREFINT_READY                                                                                         |
|           |          | ADC internal input buffer ready status, software must check this status bit before measuring          |
|           |          | VREFINT                                                                                               |
|           |          | 0: VREFINT not ready                                                                                  |
|           |          | 1: VREFINT is ready                                                                                   |
| 1         | VREFEN   | VREFINT Enable                                                                                        |
|           |          | ADC internal input buffer is enabled, software must enable this bit before measuring VREFINT          |
|           |          | 0: Disable VREFINT measurement                                                                        |
|           |          | 1: Enable VREFINT measurement                                                                         |
| 0         | Reserved | Reserved, the reset value must be maintained.                                                         |

## 12.8.6 ADC sampling time register (ADC\_ SAMPT)

Address offset: 0x10





| Bit Field | Name      | Description                                                                         |
|-----------|-----------|-------------------------------------------------------------------------------------|
| 31:5      | Reserved  | Reserved, the reset value must be maintained.                                       |
| 4:0       | SAMP[4:0] | Channel sample time selection                                                       |
|           |           | These bits are written by software to select the sample time for channel.           |
|           |           | During sample cycles channel selection bits must remain unchanged.                  |
|           |           | 00000: reserved                                                                     |
|           |           | 00001: 8 cycles(only set for working clock of 20MHz, the frequency of HSI is 40MHz) |
|           |           | 00010: 12 cycles                                                                    |
|           |           | 00011: 14 cycles                                                                    |
|           |           | 00100: 20 cycles                                                                    |
|           |           | 00101: 26 cycles                                                                    |
|           |           | 00110: 30 cycles                                                                    |
|           |           | 00111: 42 cycles                                                                    |
|           |           | 01000: 56 cycles                                                                    |
|           |           | 01001: 72 cycles                                                                    |
|           |           | 01010: 88 cycles                                                                    |
|           |           | 01011: 120 cycles                                                                   |
|           |           | 01100: 182 cycles                                                                   |
|           |           | 01101: 240 cycles                                                                   |
|           |           | 01110: 380 cycles                                                                   |
|           |           | 01111: 760 cycles                                                                   |
|           |           | 10000: 1520 cycles                                                                  |
|           |           | 10001: 3040 cycles                                                                  |

### 12.8.7 ADC watchdog high threshold register (ADC\_WDGHIGH)

Address offset: 0x14

Reset value: 0x00000FFF

| 31 |      |       |    |    |   |   |      |       |     |        | • |   |   | <br>16 |
|----|------|-------|----|----|---|---|------|-------|-----|--------|---|---|---|--------|
|    |      |       |    |    |   |   | Reso | erved |     |        |   |   |   |        |
|    |      |       |    |    |   |   |      | 1     |     |        |   |   |   |        |
| 15 |      |       | 12 | 11 |   |   |      |       |     |        |   |   |   | 0      |
|    | Rese | erved | 1  |    | 1 | 1 | 1    | 1     | HTH | [11:0] | 1 | 1 | 1 |        |
| •  | •    |       |    |    |   |   |      |       | r   | w      |   |   |   |        |

| Bit Field | Name      | Description                                                     |
|-----------|-----------|-----------------------------------------------------------------|
| 31:12     | Reserved  | Reserved, the reset value must be maintained.                   |
| 11:0      | HTH[11:0] | Analog watchdog high threshold                                  |
|           |           | These bits define the high threshold for simulating a watchdog. |

## 12.8.8 ADC watchdog low threshold register (ADC\_WDGLOW)

Address offset: 0x18



#### Reset value: 0x0000 0000



| Bit Field | Name      | Description                                                      |
|-----------|-----------|------------------------------------------------------------------|
| 31:12     | Reserved  | Reserved, the reset value must be maintained.                    |
| 11:0      | LTH[11:0] | Analog watchdog low threshold                                    |
|           |           | These bits define the lower threshold for simulating a watchdog. |

### 12.8.9 ADC regular data register x (ADC\_DATx) (x= 0..4)

Address offset: 0x1C-0x2C

Reset value: 0x0000 0000

| 31 |   |   |   |      |      |      |        |  | 20 | 19 |      |        | 16 |
|----|---|---|---|------|------|------|--------|--|----|----|------|--------|----|
|    |   | 1 | 1 | Rese | rved |      |        |  | 1  |    | SEQ, | x[3:0] |    |
| 15 |   |   |   |      |      |      |        |  |    |    | 1    | r      | 0  |
|    | 1 |   | 1 |      |      | DATx | [15:0] |  |    |    | 1    |        |    |

r

| Bit Field | Name       | Description                                                                                           |
|-----------|------------|-------------------------------------------------------------------------------------------------------|
| 31:20     | Reserved   | Reserved, the reset value must be maintained.                                                         |
| 19:16     | SEQx[3:0]  | Conversion channel of selecting proper data register                                                  |
|           |            | 0000: channel 0                                                                                       |
|           |            |                                                                                                       |
|           |            | 1001: channel 9                                                                                       |
|           |            | Others: reserved                                                                                      |
| 15:0      | DATx[15:0] | Regular data for conversions                                                                          |
|           |            | These bits are read-only and contain the conversion results of the regular channel. The data is left- |
|           |            | aligned or right-aligned.                                                                             |



# 13 Comparator (COMP)

The COMP module is used to compare the analog voltages of two inputs and output high/low levels based on the comparison results. When the input voltage of "INP" is higher than the input voltage of "INM", the comparator output is high; when the input voltage of "INP" is lower than the input voltage of "INM", the comparator output is low.

### 13.1 COMP system connection block diagram

The COMP module supports an independent comparator, which is connected to the APB bus.



#### Figure 13-1 Comparator system connection diagram

## **13.2 COMP features**

- Operate votage 2.4~5.5V
- A comparator with substraction, support positive port input voltage(500mV~VDD-200mV) minus a reference voltage(300/200/100/0mV)
- Support filter clock
- Output polarity can be configured high and low
- The hysteresis configuration can be configured with none, low, medium, or high
- The comparison result can be output to the I/O port or trigger timer, which is used to capture events, OCREF\_CLR events, brake events, and generate interrupts
- Input channel can select I/O ports
- Can be equipped with read-only or read-write, it needs to be reset to unlock when locked
- Support blanking, configurable blanking source to generate blanking
- Filter window size can be configured
- Filter threshold size can be configured
- The sampling frequency for filtering can be configured



## **13.3 COMP configuration process**

Complete configuration items are as follows. If the default configuration is used, skip the corresponding configuration items.

- 1. Configurable hysteresis level COMP\_CTRL.HYST[1:0].
- 2. Configure the output polarity COMP\_CTRL.POL.
- 3. Configuration input selection, comparator positive COMP\_CTRL.INPSEL, negative COMP\_CTRL.INMSEL.
- 4. Configure the subtraction value at the positive input COMP\_CTRL.CMPVOS[1:0].
- 5. Configure output selection COMP\_CTRL.OUTTRG[2:0].
- 6. Configure the blanking source COMP\_CTRL.BLKING.
- 7. Configure the filter sampling window COMP\_FILC.SAMPW[4:0].
- 8. Configure the threshold COMP\_FILC.THRESH[4:0](threshold should be greater than COMP\_FILC.SAMPW[4:0]/2).
- 9. Configure the filter sampling frequency (for timer applications, sampling frequency should be greater than 5MHz).
- 10. Enable COMP\_FILC.FILEN filter.
- 11. Enable COMP\_CTRL.EN on the comparator.

Note: For the above steps, the filter should be enabled first and then the comparator should be enabled. The comparator should be enabled after the filtering (if enabled) is configured and enabled. In addition, when the comparator control register is locked, the LOCK can be cancelled only through reset.

## 13.4 COMP working mode

#### 13.4.1 Independent comparator

One comparator can be configured independently to complete the comparator function. The output of the comparator can be output to I/O ports. The comparator supports different remapping ports. and the output of the comparator can be selected and connected to the corresponding port through configuration.

Comparator output, support trigger events, for example, it can be configured as timer 1 brake function.

Note: Refer to the comparator interconnection for specific configuration

### **13.5** Comparator interconnection

For interconnection of comparator output ports, please refer to the AFIO remapping chapter, Remap IO multiplexing function in GPIOx\_AFL/AFH.

COMP\_OUT can be mapped to PA8, The comparator INP pins have the following configuration:



| INPSEL | COMP |
|--------|------|
| 0      | PB0  |
| 1      | PA5  |

The comparator INM pins have the following configuration

| INMSEL | COMP |
|--------|------|
| 0      | PB1  |
| 1      | PA4  |

The signals of TRIG output by the comparator have the following interconnections

| TRIG  | COMP            |
|-------|-----------------|
| 000   | NC              |
| 001   | TIM1_BKIN       |
| 010   | TIM1_IC1        |
| 011   | TIM1_OCrefclear |
| 100   | TIM3_IC1        |
| 101   | TIM3_OCrefclear |
| Other |                 |

### **13.6 Interrupt**

COMP supports interrupt response. There are two types of interrupts.

- The polarity of COMP\_CTRL.POL is not reversed and the interrupt is enabled. When INPSEL > INMSEL, the comparator interrupt will be generated when COMP\_CTRL.OUT is set to 1 by hardware.
- The polarity of COMP\_CTRL.POL is reversed and the interrupt is enabled. When INPSEL < INMSEL, the comparator interrupt will be generated when COMP\_CTRL.OUT is set to 1 by hardware.

## **13.7 COMP registers**

#### 13.7.1 **COMP registers**

| Offset | Register    | 31         31           30         30           30         29           22         25           24         22           25         23           26         22           27         23           28         20           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11           11         11      11         11 |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000h   | COMP_INTEN  | Reserved Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|        | Reset Value | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 004h   | COMP_INTSTS | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|        | Reset Value | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 008h   |             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 00Ch   | COMP_LOCK   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### Table 13-1 Register overview

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| Offset            | Register    | 31 | 30 | 29 | ő | 87 | 27 | 26 | 25  | 6   | 23    | 3   | 22 | 17   | 20  | 2 2 | 18  | 16   | 15       |   | 14     | 13 | 12        | 11  | 10       | 6  | 8      | 7     | 9     | 5        | 4      | 3     | 5      | 1      | 0     |
|-------------------|-------------|----|----|----|---|----|----|----|-----|-----|-------|-----|----|------|-----|-----|-----|------|----------|---|--------|----|-----------|-----|----------|----|--------|-------|-------|----------|--------|-------|--------|--------|-------|
|                   | Reset Value |    |    |    |   |    |    |    |     |     |       |     |    |      |     |     |     |      |          |   |        |    |           |     |          |    |        |       |       |          |        |       |        |        | 0     |
| 010h              | COMP_CTRL   |    |    |    |   |    |    |    | Res | erv | /ed   |     |    |      |     |     | OUT |      | Reserved |   | BLKING |    | HYST[1:0] | TOd | Reserved |    | OUTTRG | 5     |       | Reserved | CMPVOS | [1:0] | INPSEL | INMSEL | EN    |
|                   | Reset Value |    |    |    |   |    |    |    |     |     |       |     |    |      |     |     | 0   |      |          |   | 0      | 0  | 0         | 0   |          | 0  | 0      | 0     |       |          | 0      | 0     | 0      | 0      | 0     |
| 014h              | COMP_FILC   |    |    |    |   |    |    |    |     |     |       |     | Re | eser | ved |     |     |      |          |   |        |    |           |     |          | SA | MPW    | [4:0] |       |          | THI    | RESH  | [4:0]  | •      | FILEN |
| -                 | Reset Value |    |    |    |   |    |    |    |     |     |       |     |    |      |     |     |     |      |          |   |        |    |           |     | 0        | 0  | 0      | 0     | 0     | 0        | 0      | 0     | 0      | 0      | 0     |
| 018h              | COMP_FILP   |    |    |    |   |    |    |    |     | R   | eserv | /ed |    |      |     |     |     |      |          |   |        |    |           |     |          |    | CLK    | PSC[1 | 15:0] |          |        |       |        |        |       |
|                   | Reset Value |    |    |    |   |    |    |    |     |     |       |     |    |      |     |     |     |      | 0        | 1 | 0      | 0  | 0         | 0   | 0        | 0  | 0      | 0     | 0     | 0        | 0      | 0     | 0      | 0      | 0     |
| 01Ch<br>~<br>03Ch |             |    |    |    |   |    |    |    |     |     |       |     |    |      |     |     | Re  | serv | ed       |   |        |    |           |     |          |    |        |       |       |          |        |       |        |        |       |

## 13.7.2 COMP interrupt enable register (COMP\_INTEN)

#### Address offset :0x00

Reset value :0x0000 0000

| 31 |   |   | <br>- |   | <br>     |       | <br> |   |   |   |   | 16     |
|----|---|---|-------|---|----------|-------|------|---|---|---|---|--------|
|    |   |   |       |   | Rese     | erved |      |   |   |   |   |        |
|    | 1 | 1 |       |   |          | 1     |      |   |   | 1 |   |        |
| 15 | 1 |   |       | 1 | <br>     |       | <br> |   |   |   | 1 |        |
|    |   |   |       |   | Reserved |       |      |   |   |   |   | CMPIEN |
| L  | 1 | 1 | <br>1 | 1 |          | 1     |      | 1 | 1 | 1 | 1 | rw     |

| Bit Field | Name     | Description                                   |
|-----------|----------|-----------------------------------------------|
| 31:1      | Reserved | Reserved, the reset value must be maintained. |
| 0         | CMPIEN   | Comparator interrupt enable register.         |
|           |          | 0: Disable                                    |
|           |          | 1: Enable                                     |

## 13.7.3 COMP interrupt status register (COMP\_INTSTS)

Address offset :0x04





| Bit Field | Name     | Description                                   |
|-----------|----------|-----------------------------------------------|
| 31:1      | Reserved | Reserved, the reset value must be maintained. |
| 0         | CMPIS    | The status of comparator is interrupted       |
|           |          | Write 0 to clear                              |

### 13.7.4 COMP lock register (COMP\_LOCK)

Address offset :0x0C

Reset value :0x0000 0000

| 31 |   |   |   |   |   |          |      |      |      |   |    | 16    |
|----|---|---|---|---|---|----------|------|------|------|---|----|-------|
|    | 1 |   |   | I |   | Rese     | rved |      | I    | I | 1  |       |
|    | ļ | 1 | 1 | 1 | 1 | 1        | 1    |      | 1    | 1 | ·I |       |
| 15 |   |   |   |   |   | <br>     |      | <br> | <br> |   | 1  | 0     |
|    |   | 1 |   |   |   | Reserved | 1    |      |      |   |    | CMPLK |
| •  |   |   |   |   |   |          |      |      |      |   |    |       |

| Bit Field | Name     | Description                                                                            |  |  |  |
|-----------|----------|----------------------------------------------------------------------------------------|--|--|--|
| 31:1      | Reserved | Reserved, the reset value must be maintained.                                          |  |  |  |
| 0         | CMPLK    | This bit can only be reset then written once by software. If software is set to 1, the |  |  |  |
|           |          | COMP_CTRL register will become a read-only register.                                   |  |  |  |
|           |          | 0: COMP_CTRL\ COMP_FIL\ COMP_FILP is read-write.                                       |  |  |  |
|           |          | 1: COMP_CTRL\ COMP_FIL\ COMP_FILP is read-only.                                        |  |  |  |

## 13.7.5 COMP control register (COMP\_CTRL)

Address offset :0x10

| 31       |        |     |        |     |          |      |          |    |      |       |      |         | 18     | 17      | 16       |
|----------|--------|-----|--------|-----|----------|------|----------|----|------|-------|------|---------|--------|---------|----------|
|          |        |     | 1      | 1   |          | Rese | erved    | 1  |      |       | 1    | 1       |        | OUT     | Reserved |
| 15       | 14     | 13  | 12     | 11  | 10       | 9    |          | 7  | 6    | 5     | 4    | 3       | 2      | rw<br>1 | 0        |
| Reserved | BLKING | HYS | T[1:0] | POL | Reserved | 0    | UTTRG[2: | 0] | Rese | erved | CMPV | OS[1:0] | INPSEL | INMSEL  | EN       |
|          | rw     | 1   | r      | rw  |          |      | rw       |    |      |       | r    | w       | rw     | rw      | rw       |

| Bit Field | Name     | Description                                              |  |  |
|-----------|----------|----------------------------------------------------------|--|--|
| 31:18     | Reserved | Reserved, the reset value must be maintained.            |  |  |
| 17        | OUT      | This read-only bit is COMP output state.                 |  |  |
|           |          | 0: Output is low                                         |  |  |
|           |          | 1: Output is high                                        |  |  |
| 16:15     | Reserved | Reserved, the reset value must be maintained.            |  |  |
| 14        | BLKING   | Comparator output is selected by blanking source control |  |  |
|           |          | 0: No blanking                                           |  |  |
|           |          | 1: TIM1 OC5 selected as blanking source                  |  |  |



| Bit Field | Name        | Description                                                                 |  |  |
|-----------|-------------|-----------------------------------------------------------------------------|--|--|
| 13:12     | HYST[1:0]   | These bits control the hysteresis level.                                    |  |  |
|           |             | 00: No hysteresis                                                           |  |  |
|           |             | 01: Low hysteresis                                                          |  |  |
|           |             | 10: Moderate hysteresis                                                     |  |  |
|           |             | 11: High hysteresis                                                         |  |  |
| 11        | POL         | This bit is used to invert the COMP output.                                 |  |  |
|           |             | 0: Output is not reversed                                                   |  |  |
|           |             | 1: Output is reversed                                                       |  |  |
| 10        | Reserved    | Reserved, the reset value must be maintained.                               |  |  |
| 9:7       | OUTTRG[2:0] | These bits select which Timer input must be connected with the COMP output. |  |  |
|           |             | 000: Reserved                                                               |  |  |
|           |             | 001: TIM1_BKIN                                                              |  |  |
|           |             | 010: TIM1_IC1                                                               |  |  |
|           |             | 011: TIM1_OCrefclear                                                        |  |  |
|           |             | 100: TIM3_IC1                                                               |  |  |
|           |             | 101: TIM3_OCrefclear                                                        |  |  |
| 6:5       | Reserved    | Reserved, the reset value must be maintained.                               |  |  |
| 4:3       | CMPVOS[1:0] | the subtraction value at the positive end.                                  |  |  |
|           |             | 00: no subtract;                                                            |  |  |
|           |             | 01: subtract 100mv;                                                         |  |  |
|           |             | 10: subtract 200mv;                                                         |  |  |
|           |             | 11: subtract 300mv;                                                         |  |  |
| 2         | INPSEL      | COMP positive input select                                                  |  |  |
|           |             | 0: PB0                                                                      |  |  |
|           |             | 1: PA5                                                                      |  |  |
| 1         | INMSEL      | COMP negative input select                                                  |  |  |
|           |             | 0: PB1                                                                      |  |  |
|           |             | 1: PA4                                                                      |  |  |
| 0         | EN          | This bit switches COMP ON/OFF.                                              |  |  |
|           |             | 0: Disable                                                                  |  |  |
|           |             | 1: Enable                                                                   |  |  |

#### COMP filter control register (COMP\_FILC) 13.7.6

Address offset :0x14

Reset value :0x0000 0000



Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| Bit Field | Name        | Description                                                           |  |  |  |
|-----------|-------------|-----------------------------------------------------------------------|--|--|--|
| 31:11     | Reserved    | Reserved, the reset value must be maintained.                         |  |  |  |
| 10:6      | SAMPW[4:0]  | Sampling window size of low pass filter, sampling window = SAMPW + 1. |  |  |  |
| 5:1       | THRESH[4:0] | Low pass filter threshold, the value must be greater than SAMPW / 2   |  |  |  |
| 0         | FILEN       | Filter enable bit                                                     |  |  |  |
|           |             | 0: Disable                                                            |  |  |  |
|           |             | 1: Enable                                                             |  |  |  |

## 13.7.7 COMP filter clock register (COMP\_FILP)

Address offset :0x18



| Bit Field | Name         | Description                                                                   |  |  |  |
|-----------|--------------|-------------------------------------------------------------------------------|--|--|--|
| 31:16     | Reserved     | Reserved, the reset value must be maintained.                                 |  |  |  |
| 15:0      | CLKPSC[15:0] | Low pass filter sampling clock predivision, system clock frequency division = |  |  |  |
|           |              | CLKPSC + 1.                                                                   |  |  |  |
|           |              | 0: Every clock                                                                |  |  |  |
|           |              | 1: Every 2 clocks                                                             |  |  |  |
|           |              | 2: Every 3 clocks                                                             |  |  |  |
|           |              |                                                                               |  |  |  |
|           |              | 65535: Every 65536 clocks                                                     |  |  |  |



## 14 Inter-integrated circuit bus(I<sup>2</sup>C)

## **14.1 Introduction**

I2C(Inter-Integrated Circuit) bus is a widely used bus structure, it has only two bidirectional lines, namely data bus SDA and clock bus SCL. All devices compatible with I2C bus can communicate directly with each other through I2C bus with these two lines.

I2C interface connects microcontroller and serial I2C bus, and can be used for communication between MCU and external I2C devices. It supports standard speed mode and fast mode, it supports CRC calculation and verification, it also provides multi-master function to control all I2C bus specific timing, protocol, arbitration.

## 14.2 Main features

- Same interface can have both master function and slave function
- Parallel-bus to I<sup>2</sup>C protocol converter
- Supports 7-bit/10-bit address mode and broadcast addressing
- As I<sup>2</sup>C master, it can generate clock, start and stop signal
- As I<sup>2</sup>C slave, it supports programmable address detection, stop bit detection function
- Support standard speed mode(up to 100 kHz), fast mode(up to 400 kHz) and fast plus mode(up to 1MHz)
- Support interrupt vector: byte transfer successfully interrupt and error event interrupt
- Optional clock extending function
- Optional PEC (Packet Error Check) generation and verification
- Programmable analog and digital noise filters

### 14.3 Function description

I2C interface is connected to I2C bus through data pin (SDA) and clock pin (SCL) to communicate with external devices. It can be connected to standard (up to 100kHz) or fast (up to 400kHz,1MHz) I2C bus. I2C module converts data from serial to parallel when receiving, and converts data from parallel to serial when sending. It support interrupt mode, users can enable or disable interrupt according to their needs.

### 14.3.1 SDA and SCL line control

I2C module has two interface lines: serial data line (SDA) and serial clock line (SCL). Devices connected to the bus and transmit information to each other through these two wires. SDA and SCL are two-way wires, it should connected to a current source or the positive of the power supply with a pull-up resistor. When the bus is idle, both lines are high level. The output of device which is connected to the bus must have open drain or open collector to provide wired-AND functionality. The data on I2C bus can reach 100 kbit/s in standard mode and 1000 kbit/s in fast mode. Since devices of different processors may be connected to the I2C bus, the levels of logic '0' and logic '1' are not fixed



and depend on the actual level of VDD.

If the clock extending is allowed, the SCL line is pulled low which can be avoided the overload error during receiving and the under load error during transmission.

For example, when in the transmission mode, if the transmit data register is empty and the byte transfer finish bit is set (I2C\_STS1.TXDATE = 1, I2C\_STS1.BSF = 1), the I2C interface keeps the clock line low before transmission to wait for the software to read STS1 and write the data into the data register (both buffer and shift register are empty); when In the receive mode, if the data register is not empty and the byte transfer finish bit is set (I2C\_STS1.RXDATNE = 1, I2C\_STS1.BSF = 1), the I2C interface keeps the clock line low after receiving the data byte, waiting for the software to read STS1, and then read the data register(buffer and shift register are full).

If clock extending is disable in slave mode, if the receive data register is not empty (I2C\_STS1.RXDATNE = 1) in the receive mode, and the data has not been read before receiving the next byte, an overrun error will issue and the last word byte will be discarded. In transmit mode, if the transmit data register is empty (I2C\_STS1.TXDATE = 1), no new data is written into the data register before the next byte must be sent, an underrun error will issue. The same byte will be send repeatedly. In this case, duplicate write conflicts are not controlled.

#### 14.3.2 Software communication process

The data transmission of I2C device is divided into master and slave. Master is the device responsible for initializing the transmission of data on the bus and generating clock signal. At this time, any addressed device is a slave. Whether the I2C device is a master or a slave, it can send or receive data. Therefore, the I2C interface supports four operation modes:

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

After system reset, I2C works in slave mode by default. The I2C interface is configured by software to send a start bit on the bus, and then the interface automatically switches from the slave mode to the master mode. When arbitration is lost or a stop signal is generated, the interface will switched to the slave mode from the master mode.

The functional block diagram of I<sup>2</sup>C interface is shown in the figure below.







#### 14.3.2.1 Start and stop conditions

All data transfers always start with the start bit and end with the stop bit. The start and stop conditions are generated by software in the master mode. Start bit is a level conversion from high to low on SDA line when SCL is high. Stop bit is a level conversion from low to high on SDA line when SCL is high. as shown in the figure below.

#### Figure 14-2 I2C bus protocol



#### 14.3.2.2 Clock synchronization and Arbitration

The I2C module supports multi-master arbitration, which means two masters can start transferring data on an idle bus at the same time. So some mechanisms are needed to decide which master takes control of the bus, which is usually done through Clock Synchronization and Arbitration.

I2C module has two key features:

SDA and SCL are drain open circuit structures, and the signal "wire-and" logic is realized through an external



pull-up resistor.

SDA and SCL pins will also detect the level on the pin while outputting the signal to check whether the output is consistent with the previous output.

This provides the hardware basis for "Clock Synchronization" and "Bus Arbitration".

The I2C device on the bus is to output logic 0 by "grounding the line". Based on the characteristics of the I2C bus, if one device sends logic 0 and the other sends logic 1, then the line sees only logic 0, so there is no possibility of level conflicts on the line.

The physical connection of the bus allows the master to read data while writing data to the bus. In this way, when two masters are competing for the bus, the one that sends logic 0 does not know the occurrence of the competition. Only the one that sends logic 1 will find the conflict (when writing a logic 1, but read 0) and exit the competition.

#### **Clock synchronization**

Multiple masters can generate clocks on an idle bus at the same time. The high-to-low switching of the SCL line causes the devices to begin counting their low-level periods, and once the device's clock goes low, it keeps the SCL line in this state until the high-level of the clock is reached. However, if another clock is still in the low period, the low-to-high switch of this clock will not change the state of the SCL line. Therefore, the SCL line is kept low by the device with the longest low-level period. A device with a short low-level period will enter a high-level wait state.

When all related devices have counted their low-level periods, the clock line is released and goes high-level, after which there is no difference in the state of the device clock and SCL lines, and all devices will begin counting their high-level periods, the device that completes the high-level period first will pull the SCL line low again.

In this way, the low-level period of the generated synchronous SCL clock is determined by the device with the longest low-level clock period, and the high-level period is determined by the device with the shortest high-level clock period.

#### Arbitration

Arbitration, like synchronization, is to resolve bus control conflicts in the case of multiple masters. The arbitration process has nothing to do with the slave. When the two masters both produce a valid start bit when the bus is idle, in this case, it is necessary to decide which master will complete the data transmission. This is the process of arbitration.

Each master controller does not have the priority level of controlling the bus, which is all determined by arbitration. The bus control is determined and carried out bit by bit. They follow the principle of "low level first", that is, whoever sends the low level first will control the bus. During the arbitration of each bit, when SCL is high, each host checks whether its own SDA level is the same as that sent by itself. In theory, if the content transmitted by two hosts is exactly the same, then they can successfully transmit without errors. If a host sends a high level but detects that the SDA line is low, it considers that it has lost arbitration and shuts down its SDA output driver, while the other host continues to complete its own transmission.

#### 14.3.2.3 I2C data communication flow

Each I2C device is identified by a unique address. According to the device function, they can be either a transmitter or a receiver.

The I2C host is responsible for generating the start bit and the end bit in order to start and end a transmission. And is responsible for generating the SCL clock.

The I2C module supports 7-bit and 10-bit addresses, and the user can configure the address of the I2C slave through



software. After the I2C slave detects the start bit on the I2C bus, it starts to receive the address from the bus, and compares the received address with its own address. Once the two addresses are matched, the I2C slave will send an acknowledgement (ACK) and respond to subsequent commands on the bus: send or receive the requested data. In addition, if the software opens a broadcast call, the I2C slave always sends a confirmation response to a broadcast address (0x00).

Data and address are transmitted in 8-bit width, with the most significant bit first. The 1 or 2 bytes following the start condition is the address (1 byte in 7-bit mode, 2 bytes in 10-bit mode). The address is only sent in master mode. During the 9th clock period after 8 clocks of a byte transmission, the receiver must send back an acknowledge bit (ACK) to the transmitter, as shown in the Figure 14-2 I2C bus protocol.

Software can enable or disable acknowledgement (ACK), and can set the I2C interface address (7-bit, 10-bit address or broadcast call address).

## 14.3.2.4 I2C slave transmission mode

In slave mode, the transmission reception flag bit (I2C\_STS2.TRF) indicates whether it is currently in receiver mode or transmission mode. When sending data to I2C bus in transmission mode, the software should follow the following steps:

- 1. First, enable I2C peripheral clock and configure the related register in I2C\_CTRL2, ensuring the correct I2C timing. After these two steps are completed, I2C runs in slave mode, waiting for receiving start bit and address.
- 2. I2C slave receives a start bit first, and then receives a matching 7-bit or 10-bit address. I2C hardware will set the I2C\_STS1.ADDRF(received address and matched its own address). The software should monitor this bit regularly or have an interrupt to monitor this bit. After this bit is set, the software reads I2C\_STS1 register and then read I2C\_STS2 register to clear the I2C\_STS1.ADDRF bit. If the address is in 10 bit format, the I2C master should then generate a START and send an address header to the I2C bus. After detecting START and the following address header, the slave will continue to set I2C\_STS1.ADDRF bit. The software continues to read I2C\_STS1 register and read I2C\_STS2 register to clear the I2C\_STS1.ADDRF bit a second time.
- 3. I2C enters the data sending state, and now shift register and data register I2C\_DAT are all empty, so the hardware will set the I2C\_STS1.TXDATE(send data empty). At this time, the software can write the first byte data to I2C\_DAT register, however, because the byte of the I2C\_DAT register is immediately moved into the internal shift register, the I2C\_STS1.TXDATE bit is not cleared to zero. When the shift register is not empty, I2C starts to send data to I2C bus.
- 4. During the sending of the first byte, the software writes the second byte to I2C\_DAT, neither the I2C\_DAT register nor the shift register is empty. The I2C\_STS1.TXDATE bit is cleared to 0.
- 5. After the first byte is sent, I2C\_STS1.TXDATE is set again, and the software writes the third byte to I2C\_DAT, the same time, the I2C\_STS1.TXDATE bit is cleared.After that, as long as there is still data to be sent and I2C\_STS1.TXDATE is set to 1, the software can write a byte to I2C\_DAT register.
- 6. During the sending of the second last byte, the software writes the last data to the I2C\_DAT register to clear the I2C\_STS1.TXDATE flag bit, and then the I2C\_STS1.TXDATE status is no longer concerned. The I2C\_STS1.TXDATE bit is set after the second last byte is sent until the stop end bit is detected.
- 7. According to the I2C protocol, the I2C master will not send a ACK to the last byte received. Therefore, after the last byte is sent, the I2C\_STS1.ACKFAIL bit (acknowledge fail) of the I2C slave will be set to notify the software



of the end of sending. The software writes 0 to the I2C\_STS1.ACKFAIL bit to clear this bit.



Figure 14-3 Slave transmitter transfer sequence diagram

Instructions:

- 1. EV1: I2C\_STS1.ADDRF = 1, read STS1 and then STS2 to clear the event.
- 2. EV3-1: I2C\_STS1.TXDATE=1, shift register is empty, data register is empty, write DAT.
- 3. EV3: I2C\_STS1.TXDATE=1, shift register is not empty, data register is empty, write DAT will clear the event.
- 4. EV3-2: I2C\_STS1.ACKFAIL=1, ACKFAIL bit of STS1 register write "0" to clear the event.

Note:

- *a) EV1 and EV3\_1 event prolongs the low SCL time until the end of the corresponding software sequence.*
- *b)* The software sequence of EV3 must be completed before the end of the current byte transfer.

### 14.3.2.5 I2C slave receiving mode

When receiving data in slave mode, the software should operate as follows:

- 1. First, enable I2C peripheral clock and configure the related register in I2C\_CTRL2 ensuring the correct I2C timing. After these two steps are completed, I2C runs in slave mode, waiting for receiving start bit and address.
- 2. After receiving the START condition and the matched 7-bit or 10-bit address, I2C hardware will set I2C\_STS1.ADDRF bit(the address received and matched with its own address) to 1. This bit should be detected by software polling or interrupt. After it is found that it is set, the software clears the I2C\_STS1.ADDRF bit by reading I2C\_STS1 register first and then I2C\_STS2 register. Once the I2C\_STS1.ADDRF bit is cleared, The I2C slave starts to receive data from the I2C bus.
- 3. When the first byte is received, the I2C\_STS1.RXDATNE bit (the received data is not empty) is set to 1 by hardware. If the I2C\_CTRL2.EVTINTEN and I2C\_CTRL2.BUFINTEN bits are set, an interrupt is generated. The software should check this bit by polling or interrupt. Once it is found that it is set, the software can read the first byte of I2C\_DAT register, and then the I2C\_STS1.RXDATNE bit is cleared to 0. Note that if the



I2C\_CTRL1.ACKEN bit is set, after receiving a byte, the slave should generate a response pulse.

- 4. At any time, as long as the I2C\_STS1.RXDATNE bit is set to 1, the software can read a byte from the I2C\_DAT register. When the last byte is received, I2C\_STS1.RXDATNE is set to 1 and the software reads the last byte.
- 5. When the slave detects the STOP bit on I2C bus, set I2C\_STS1.STOPF to 1, and if the I2C\_CTRL2.EVTINTEN bit is set, an interrupt will be generated. The software clears the I2C\_STS1.STOPF bit by reading the I2C\_STS1 register before writing the I2C\_CTRL1 register (see EV4 in the following figure).



#### Figure 14-4 Slave receiver transfer sequence diagram

Instructions:

- 1.  $EV1: I2C\_STS1.ADDRF = 1$ , read STS1 and then STS2 to clear the event.
- 2. EV2: I2C\_STS1.RXDATNE =1, reading DAT will clear this event.
- 3. EV4: I2C\_STS1.STOPF=1, reading STS1 and then writing the CTRL1 register will clear this event.

Note:

- a) EV1 event prolongs the time when SCL is low until the end of the corresponding software sequence.
- *b)* The software sequence of EV2 must be completed before the end of the current byte transmission.

### 14.3.2.6 I2C master transmission mode

In the master mode, the I2C interface starts data transmission and generates a clock signal. Serial data transmission always starts with a start condition and ends with a stop condition. When the START condition is generated on the bus through the start bit, the device enters the master mode.

When sending data to I2C bus in master mode, the software should operate as follows:

1. First, enable the I2C peripheral clock, and configure the related registers in I2C\_CTRL2 to ensure the correct I2C timing. When these two steps are completed, I2C runs in the slave mode by default, waiting for receiving the start bit and address.



- 2. When BUSY=0, I2C\_CTRL1.STARTGEN bit set to 1, and the I2C interface will generate a start condition and switch to the master mode (I2C\_STS2.MSMODE=1).
- 3. Once the start condition is issued, I2C hardware will set I2C\_STS1.STARTBF bit(START bit flag)and then enters the master mode. If the I2C\_CTRL2.EVTINTEN bit is set, an interrupt will be generated. Then the software reads the I2C\_STS1 register and then writes a 7-bit address bit or a 10-bit address bit with an address header to the I2C\_DAT register to clear the I2C\_STS1.STARTBF bit. After the I2C\_STS1.STARTBF bit is cleared to 0, I2C starts sending addresses or address headers to I2C bus.

In 10-bit address mode, sending a header sequence will generate the following events:

- ◆ I2C\_STS1.ADDR10F bit is set by hardware, and if I2C\_CTRL2.EVTINTEN bit is set, an interrupt is generated. Then the master reads the STS1 register, and then writes the second address byte into the DAT register.
- ◆ I2C\_STS1.ADDRF bit is set by hardware, and if I2C\_CTRL2.EVTINTEN bit is set, an interrupt is generated. Then the master reads the STS1 register, followed by the STS2 register.

*Note:* In the transmitter mode, the master device first sends the header byte (11110xx0) and then sends the lower 8 bits of the slave address. (where xx represents the highest 2 bits of the 10-bit address).

In the 7-bit address mode, only one address byte needs to be sent out. Once the address byte is sent out:

◆ I2C\_STS1.ADDRF bit is set by hardware, and if I2C\_CTRL2.EVTINTEN bit is set, an interrupt is generated. Then the master device waits for reading the STS1 register once, followed by reading the STS2 register.

Note: in the transmitter mode, when the master sends the slave address, set the lowest bit to "0".

*Note:* In 7-bit address mode, don't set the slave address to 0xF0 to prevent the I2C\_STS1.ADDR10F bit from being set by hardware.

- 4. After the 7-bit or 10-bit address bit is sent, the I2C hardware sets the I2C\_STS1.ADDRF bit (address has been sent) to 1, if the I2C\_CTRL2.EVTINTEN bit is set, an interrupt is generated, and the software is cleared by reading the I2C\_STS1 register and then the I2C\_STS2 register I2C\_STS1.ADDRF.
- 5. I2C enters the data transmission state. Because the shift register and the data register (I2C\_DAT) are empty, the hardware sets the I2C\_STS1.TXDATE bit (transmission data empty) to 1, and then the software writes the first byte of data to the I2C\_DAT register, but because the byte written into the I2C\_DAT register is immediately moved into the internal shift register, the I2C\_STS1.TXDATE bit will not be cleared at this time. Once the shift register is not empty, I2C starts sending data to the bus.
- 6. During the transmission of the first byte, the software writes the second byte to I2C\_DAT, and I2C\_STS1.TXDATE is cleared at this time. At any time, as long as there is data waiting to be sent and the I2C\_STS1.TXDATE bit is set to 1, the software can write a byte to the I2C\_DAT register.
- 7. In the process of sending the penultimate byte, the software writes the last byte of data to I2C\_DAT to clear the I2C\_STS1.TXDATE flag bit. After that, there is no need to care about the status of the I2C\_STS1.TXDATE bit. The I2C\_STS1.TXDATE bit will be set after the penultimate byte is sent, and will be cleared when the stop bit (STOP) is sent.
- 8. After the last byte is sent, because the shift register and the I2C\_DAT register are empty at this time, the I2C host sets the I2C\_STS1.BSF bit (byte transmission end), and the I2C interface will keep SCL low before clearing the I2C\_STS1.BSF bit. After reading I2C\_STS1, writing to the I2C\_DAT register will clear the I2C\_STS1.BSF



bit. The software sets the I2C\_CTRL1.STOPGEN bit at this time to generate a stop condition, and then the I2C interface will automatically return to the slave mode (I2C\_STS2.MSMODE bit is cleared).



Figure 14-5 Master transmitter transfer sequence diagram

### Instructions:

- 1. EV5: I2C\_STS1.STARTBF = 1, reading STS1 and writing the address to the DAT register will clear the event.
- 2. EV6: I2C\_STS1.ADDRF = 1, read STS1 and then STS2 to clear the event.
- 3. EV8\_1: I2C\_STS1.TXDATE = 1, shift register is empty, data register is empty, write DAT register.
- 4. EV8: I2C\_STS1.TXDATE = 1, shift register is not empty, data register is empty, write to DAT register will clear the event.
- 5. EV8\_2: I2C\_STS1.TXDATE = 1, I2C\_STS1.BSF = 1, request to set stop bit. These two events are cleared by the hardware when a stop condition is generated.
- 6. EV9: I2C\_STS1.ADDR10F = 1, read STS1 and then write to DAT register to clear the event.

Note:

- *a) EV5, EV6, EV9, EV8\_1 and EV8\_2 event prolonged the low SCL time until the end of the corresponding software sequence.*
- *b)* The software sequence of EV8 must be completed before the end of the current byte transfer.
- c) When I2C\_STS1.TXDATE or I2C\_STS1.BSF bit is set, stop condition should be arranged when EV8\_2 occurs.

### 14.3.2.7 I2C master receiving mode

Support BYTENUM byte control mode, in the master receive mode, after configuring the number of bytes received, the hardware automatically ends the communication, without software intervention to configure NACK and send START/STOP conditions, of course, you can also use the ordinary master receive mode.

In master mode, software receiving data from I2C bus should follow the following steps:



1. First, enable the I2C peripheral clock and configure the related registers in I2C\_CTRL2, in order to ensure that the correct I2C timing is output. After enabling and configuring, I2C runs in slave mode by default, waiting to receive the start bit and address.

Note: If you need to enable master receive byte control, you need to additionally enable I2C\_BYTENUM.BYTENUMEN after enabling the I2C peripheral clock in this step, and configure the number of bytes to received through I2C\_BYTENUM.BYTENUM, and I2C\_BYTENUM.RXFSEL selects the master to send START or STOP conditions after the receive is finish.

- 2. When BUSY=0, set the I2C\_CTRL.STARTGEN bit, and the I2C interface will generate a start condition and switch to the master mode (I2C\_STS2.MSMODE bit is set to 1).
- 3. Once the start condition is issued, the I2C hardware sets I2C\_STS1.STARTBF(start bit flag) and enters the host mode. If the I2C\_CTRL2.EVTINTEN bit is set to 1, an interrupt will be generated. Then the software reads the I2C\_STS1 register and then writes a 7-bits address or a 10-bits address with an address header to the I2C\_DAT register, in order to clear the I2C\_STS1.STARTBF bit. After the I2C\_STS1.STARTBF bit is cleared to 0, I2C begins to send the address or address header to the I2C bus.

In 10-bits address mode, sending a header sequence will generate the following events:

- The I2C\_STS1.ADDR10F bit is set to 1 by hardware, and if the I2C\_CTRL2.EVTINTEN bit is set to 1, an interrupt will be generated. Then the master device reads the STS1 register, and then writes the second byte of address into the DAT register.
- The I2C\_STS1.ADDRF bit is set to 1 by hardware, and if the I2C\_CTRL2.EVTINTEN bit is set to 1, an interrupt will be generated. Then the master device reads the STS1 register and the STS2 register in sequence.

Note: In the receiver mode, the master device sends the header byte (11110xx0) firstly, then sends the lower 8 bits of the slave address, and then resends a start condition followed by the header byte (11110xx1) (where xx represents the highest 2 digits of the 10-bits address).

In the 7-bits address mode, only one address byte needs to be sent, once the address byte is sent:

• The I2C\_STS1.ADDRF bit is set to 1 by hardware, and if the I2C\_CTRL2.EVTINTEN bit is set to 1, an interrupt will be generated. Then the master device waits to read the STS1 register once, and then reads the STS2 register.

Note: In the receiving mode, the master device sets the lowest bit as '1' when sending the slave address.

*Note:* In 7-bit address mode, don't set the slave address to 0xF0 to prevent the I2C\_STS1.ADDR10F bit from being set by hardware.

- 4. After the 7-bits or 10-bits address is sent, the I2C hardware sets the I2C\_STS1.ADDRF bit (address has been sent) to 1. If the I2C\_CTRL2.EVTINTEN bit is set to 1, an interrupt will be generated. The software clears the I2C\_STS1.ADDRF bit by reading the I2C\_STS1 register and the I2C\_STS2 register in sequence. If in the 10-bit address mode, software should set the I2C\_CTRL1.STARTGEN bit again to regenerate a START. After the START is generated, the I2C\_STS1.STARTBF bit will be set. The software should clear the I2C\_STS1.STARTBF bit by reading I2C\_STS1 firstly and then writing the address header to I2C\_DAT, and then the address header is sent to the I2C bus, I2C\_STS1.ADDRF is set to 1 again. The software should clear the I2C\_STS1.ADDRF bit again by reading I2C\_STS1 and I2C\_STS2 in sequence.
- 5. After sending the address and clearing the I2C\_STS1.ADDRF bit, the I2C interface enters the host receiving mode. In this mode, the I2C interface receives data bytes from the SDA line and sends them to the DAT register through the internal shift register. Once the first byte is received, the hardware will set the



I2C\_STS1.RXDATNE bit (not empty flag bit of received data) to 1, and if the I2C\_CTRL1.ACKEN bit is set to 1, an acknowledge pulse will be sent. At this time, the software can read the first byte from the I2C\_DAT register, and then the I2C\_STS1.RXDATNE bit is cleared to 0. After that, as long as I2C\_STS1.RXDATNE is set to 1, the software can read a byte from the I2C\_DAT register.

6. The master device sends a NACK after receiving the last byte from the slave device. After receiving the NACK, the slave device releases the control of SCL and SDA lines; the master device can send a stop/restart condition. In order to generate a NACK pulse after receiving the last byte, the software should clear the I2C\_CTRL1.ACKEN bit immediately after receiving the penultimate byte (N-1). In order to generate a stop/restart condition, the software must set the I2C\_CTRL1.STOPGEN bit or I2C\_CTRL1.STARTGEN to 1 after reading the penultimate data byte. This process needs to be completed before the last byte is received to ensure that the NACK is sent for the last byte.

Note: If the master receive byte control is enabled earlier, steps 6 and 7 can be ignored, the software only needs to read the bytes according to the receive flag, and the hardware will automatically send NACK and START/STOP conditions after the the receive is finish.

7. After the last byte is received, the I2C\_STS1.RXDATNE bit is set to 1, and the software can read the last byte. Since I2C\_CTRL1.ACKEN has been cleared to 0 in the previous step, I2C no longer sends ACK for the last byte, and generates a STOP bit after the last byte is sent.

Note: In ordinary master receive mode, the above steps require the number of bytes N>1. If N=1, step 6 should be executed after step 4, and it needs to be completed before the reception of byte is completed.



Figure 14-6 Master receiver transfer sequence diagram

Instructions:

- 1. EV5: I2C\_STS1.STARTBF=1, reading STS1 and then writing the address into the DAT register will clear this event.
- 2. EV6: I2C\_STS1.ADDRF=1, reading STS1 and STS2 in sequence will clear this event. In the 10-bits master receiving mode, the I2C\_CTRL1.STARTGEN should be set to 1 after this event.
- 3. EV6\_1: There is no corresponding event flag, only suitable for receiving 1 byte. Just after EV6 (that is after clearing I2C\_STS1.ADDRF), the generation bits for acknowledge and stop condition should be cleared.
- 4. EV7: I2C\_STS1.RXDATNE=1, read the DAT register to clear this event.
- 5. EV7\_1: I2C\_STS1.RXDATNE =1, read the DAT register to clear this event. Set I2C\_CTRL1.ACKEN=0 and

259 / 319



#### I2C\_CTRL1.STOPGEN=1.

6. EV9: I2C\_STS1.ADDR10F=1, reading STS1 and then writing to the DAT register will clear this event.

Note:

- a) If a single byte is received, it is NA.
- b) EV5, EV6, and EV9 events extend the low level of SCL until the corresponding software sequence ends.
- c) The EV7 software sequence shall be completed before the end of the current byte transmission.
- *d)* The software sequence of EV6\_1 or EV7\_1 shall be completed before the ACK pulse of the current transmission byte.

## 14.3.3 Error conditions description

I2C errors mainly include bus error, acknowledge fail, arbitration loss, overrun\underrun error. These errors may cause communication failure.

### 14.3.3.1 Acknowledge Failure(ACKFAIL)

The interface have a acknowledge bit is detected that does not match the expectation, it will occurs acknowledge fail error, I2C\_STS1.ACKFAIL bit is set. An interrupt occurs, when I2C\_CTRL2.ERRINTEN bit is set to 1.

When transmitter receives a NACK, The communication must be reset: Device in slave mode, hardware release the bus; Device in master mode, it must generate a stop condition from software.

### 14.3.3.2 Bus Error(BUSERR)

when address or data is transmissing,I2C interface receive external stop or start condition, it will happen a bus error, I2C\_STS1.BUSERR bit is set. An interrupt occurs, when I2C\_CTRL2.ERRINTEN bit is set to 1.

I2C device as master, the hardware does not release bus, as the same time it done not affect the current status of transfer, The current transfer will determined by software whether suspend.

I2C device as slave, when data is discarded in transmission and the bus releases by hardware, it will have two situation: If an error start condition is detected, the slave device considers a restart condition and waits for an address or a stop condition. If an error stop condition is detected, the slave device operates as a normal stop condition and the hardware releases the bus.

### 14.3.3.3 Arbitration Lost(ARLOST)

The interface have arbitration lost is detected, hardware release the bus, it will occurs arbitration lost error, I2C\_STS1.ARLOST bit is set. An interrupt occurs, when I2C\_CTRL2.ERRINTEN bit is set to 1.

I2C interface will go to slave mode automatically(I2C\_STS2.MSMODE bit is cleared). When the I2C interface lost the arbitration, in the same communication, it can not acknowledge to its slave address as slave, but it can acknowledge when the arbitration winning master retransmits a start signal.

### 14.3.3.4 Overrun/Underrun Error(OVERRUN)

In slave mode, disable clock extend prone to Overrun/Underrun Error:

When I2C interface is receiving data (I2C\_STS1.RXDATNE=1, data have received in register), and I2C\_DAT register still have previous byte has not been read, it will occurs an overrun error. In this situation, the last received

260 / 319



data is discarded. And software should clear I2C\_STS1.RXDATNE bit, transmitter retransmit last byte.

When I2C interface is sending data (I2C\_STS1.TXDATE=1, new data have not sending to register), and I2C\_DAT register still empty, it will occurs an underrun error. In this situation, the previous byte in the I2C\_DAT register is sending repeatedly. And User make sure that in the event of an underrun error, the receiver discard repeatedly byte, and transmitter should update the I2C\_DAT register at the specified time according to the I2C bus standard.

In sending the first byte, I2C\_DAT register must be written after I2C\_STS1.ADDRF bit is cleared and the before the first SCL rising edge. If cannot make sure do that, the first byte should be discard by receiver.

## 14.3.4 Packet error check

Setting the I2C\_CTRL1.PECEN bit to 1 enables the PEC function. PEC uses CRC-8 algorithm to calculate all information bytes including address and read/write bits.it can improve the reliability of communication. The CRC-8 polynomial uses by the PEC calculator is  $C(x) = x^8 + x^2 + x + 1$ .

In transmit mode, software sets I2C\_CTRL1.PEC transfer bit in the last I2C\_STS1.TXDATE event, and then PEC will be transmitted after the last byte. While in receiving mode, software sets I2C\_CTRL1.PEC transfer bit after the last I2C\_STS1.RXDATNE event, and then receives the PEC byte and compares the received PEC byte to the internally calculated PEC value. If it is not equal to the internally calculated PEC value, the receiver needs to send a NACK. If it is master receiver mode, NACK will be sent after PEC regardless of the calculated result. It should pay attention that I2C\_CTRL1.PEC bit has to be set before receiving the ACK pulse for the current byte.

When arbitration is lost, PEC calculation is invalid.

## 14.3.5 Noise filter

I2C interface standard requires that 50ns burr can be filtered on SCL/SDA. So analog filter and digital filter are added in design. By default, analog filter are enable and can be set I2C\_TMRISE.SCLAFENN/SDAAFENN to disable. The analog filter can configure I2C\_TMRSE.SCLAFE/SDAAFW to set filter burrs with the width of 5ns, 15ns, 25ns, 35ns. Digital filter can be set I2C\_TMRISE.SCLDFW/SDADFW is a non-zeor value to enable. The max width of filter is (SCLDEW[3:0] or SDADFW[3:0])\*T<sub>PCLK</sub>. Enabling the digital filter will increase the hold time of SDA and the increment is (SDADFW[3:0]+1)\*T<sub>PCLK</sub>.

## **14.4 Interrupt request**

All I2C interrupt requests are listed in the following table.

| Interrupt function  | Interrupt event             | Event flag | Set control bit |
|---------------------|-----------------------------|------------|-----------------|
|                     | Start bit sent (master)     | STARTBF    |                 |
|                     | Address sent (master) or    | ADDRF      |                 |
|                     | address matched (slave)     | ADDKF      |                 |
| I2C event interrupt | 10-bit header sent (master) | ADDR10F    | EVTINTEN        |
|                     | Received stop (slave)       | STOPF      |                 |
|                     | Data byte transfer finish   | BSF        |                 |

Table 14-1 I<sup>2</sup>C interrupt request



| Interrupt function  | Interrupt event              | Event flag | Set control bit       |
|---------------------|------------------------------|------------|-----------------------|
|                     | Receive buffer is not empty. | RXDATNE    | EVTINTEN and BUFINTEN |
|                     | Transmit buffer is empty.    | TXDATE     | EVIINTEN and BUFINTEN |
|                     | Bus error                    | BUSERR     |                       |
|                     | Lost arbitration (master)    | ARLOST     |                       |
| I2C error interrupt | Acknowledge fail             | ACKFAIL    | ERRINTEN              |
|                     | Overrun/underrun             | OVERRUN    |                       |
|                     | PEC error                    | PECERR     |                       |

Note:

- 1. STARTBF, ADDRF, ADDR10F, STOPF, BSF, RXDATNE and TXDATE are merged into a interrupt channel through logical OR.
- 2. BUSERR, ARLOST, ACKFAIL, OVERRUN and PECERR are merged into a interrupt channel through logical OR.

## 14.5 I2C registers

These peripheral registers can be operated by half word (16 bits) or word (32 bits)

## 14.5.1 I2C register overview

| Offset | Register    | 31 | 30 | 66 | 28 | 27 | 26 | 25 | 24 | 23     | 00   | 22    | 21    | 20   | 19   | 18 | 17 | 16 | 15       | 14       | 13       | 12     | 11      | 10       | 6                | 8         | L        | 9        | 5        | 4     | 3             | 2    | 1     | 0       |
|--------|-------------|----|----|----|----|----|----|----|----|--------|------|-------|-------|------|------|----|----|----|----------|----------|----------|--------|---------|----------|------------------|-----------|----------|----------|----------|-------|---------------|------|-------|---------|
| 000h   | I2C_CTRL1   |    |    |    |    |    |    |    | Re | served | I    |       |       |      |      |    |    |    | SWRESET  |          | Keserved | PEC    | ACKPOS  | ACKEN    | STOPGEN          | STARTGEN  | NOEXTEND | GCEN     | PECEN    |       | Rese          | rved |       | EN      |
|        | Reset Value |    |    |    |    |    |    |    |    |        |      |       |       |      |      |    |    |    | 0        |          |          | 0      | 0       | 0        | 0                | 0         | 0        | 0        | 0        |       |               |      |       | 0       |
| 004h   | I2C_CTRL2   |    |    |    |    |    |    |    |    |        |      | Res   | serve | ed   |      |    |    |    |          |          |          |        |         | BUFINTEN | <b>NATINITEN</b> | ERRINTEN  |          | Keserveu |          | CL    | .KFR          | EQ[5 | :0]   |         |
|        | Reset Value |    |    |    |    |    |    |    |    |        |      |       |       |      |      |    |    |    |          |          |          |        |         | 0        | 0                | 0         |          |          | 0        | 0     | 0             | 0    | 0     | 0       |
| 008h   | I2C_OADDR1  |    |    |    |    |    |    |    | Re | served | I    |       |       |      |      |    |    |    | ADDRMODE | Reserved |          | Rese   | rved    |          |                  | [0:6]MUUA |          |          | AD       | DR[7  | 7:1]          |      |       | ADDR0   |
|        | Reset Value |    |    |    |    |    |    |    |    |        |      |       |       |      |      |    |    |    | 0        |          |          |        |         |          | 0                | 0         | 0        | 0        | 0        | 0     | 0             | 0    | 0     | 0       |
| 00Ch   | I2C_OADDR2  |    |    |    |    |    |    |    |    |        |      |       |       | Rese | rved |    |    |    |          |          |          |        |         |          |                  |           |          |          | AD       | DR2[  | 7:1]          |      |       | DUALEN  |
|        | Reset Value |    |    |    |    |    |    |    |    |        |      |       |       |      |      |    |    |    |          |          |          |        |         |          |                  |           | 0        | 0        | 0        | 0     | 0             | 0    | 0     | 0       |
| 010h   | I2C_DAT     |    |    |    |    |    |    |    |    |        |      |       |       | Rese | rved |    |    |    |          |          |          |        |         |          |                  |           |          |          | Ι        | DATA  | <b>A</b> [7:0 | ]    |       |         |
|        | Reset Value |    |    |    |    |    |    |    |    |        |      |       |       |      |      |    |    |    |          |          |          |        |         |          |                  |           | 0        | 0        | 0        | 0     | 0             | 0    | 0     | 0       |
| 014h   | I2C_STS1    |    |    |    |    |    |    |    |    | F      | Rese | erved | d     |      |      |    |    |    |          |          |          | PECERR | OVERRUN | ACKFAIL  | ARLOST           | BUSERR    | TXDATE   | RXDATNE  | Reserved | STOPF | ADDR10F       | BSF  | ADDRF | STARTBF |
|        | Reset Value |    |    |    |    |    |    |    |    |        |      |       |       |      |      |    |    |    |          |          |          | 0      | 0       | 0        | 0                | 0         | 0        | 0        |          | 0     | 0             | 0    | 0     | 0       |

#### Table 14-2 I2C register overview

#### Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| 018h | I2C_STS2      | Reserved |           |        | PI       | ECVA     | AL[7:       | 0]       |   |             | DUALFLAG | -             | Keserved | GCALLADDR | Reserved | TRF   | BUSY | MSMODE |
|------|---------------|----------|-----------|--------|----------|----------|-------------|----------|---|-------------|----------|---------------|----------|-----------|----------|-------|------|--------|
|      | Reset Value   |          | 0         | 0      | 0        | 0        | 0           | 0        | 0 | 0           | 0        |               |          | 0         |          | 0     | 0    | 0      |
| 01Ch | I2C_CLKCTRL   | Reserved | FSMODE    | DUTY   |          | Keserved |             |          |   |             | CL       | KCTI          | RL[11    | :0]       |          |       |      |        |
|      | Reset Value   |          | 0         | 0      |          |          | 0           | 0        | 0 | 0           | 0        | 0             | 0        | 0         | 0        | 0     | 0    | 0      |
| 020h | I2C_TMRISE    | Reserved |           |        |          |          |             |          |   |             |          |               |          | T         | MRIS     | E[5:0 | 0]   |        |
|      | Reset Value   |          |           |        |          |          |             |          |   |             |          |               | 0        | 0         | 0        | 0     | 1    | 0      |
| 024h | I2C_GFLTRCTRL | Reserved |           |        | SCLAFENN |          | SCLAFW[1:0] | SDAAFENN |   | SDAAFW[1:0] | so       | CLDF          | W[3:     | 0]        | SE       | DADF  | W[3  | :0]    |
|      | Reset Value   |          |           |        | 0        | 0        | 0           | 0        | 0 | 0           | 0        | 0             | 0        | 0         | 0        | 0     | 0    | 0      |
| 028h | I2C_BYTENUM   | Reserved | BYTENUMEN | RXFSEL |          |          |             |          |   | BY          | TENU     | J <b>M</b> [1 | 3:0]     |           |          |       |      |        |
|      | Reset Value   |          | 0         | 0      | 0        | 0        | 0           | 0        | 0 | 0           | 0        | 0             | 0        | 0         | 0        | 0     | 0    | 0      |

# 14.5.2 I2C Control register 1 (I2C\_CTRL1)

### Address offset: 0x00

| 15          | 14   | 13    | 12  | 11         | 10    | 9           | 8            | 7            | 6    | 5     | 4 |      | _     | 1 | 0  |
|-------------|------|-------|-----|------------|-------|-------------|--------------|--------------|------|-------|---|------|-------|---|----|
| SW<br>RESET | Rese | erved | PEC | ACK<br>POS | ACKEN | STOP<br>GEN | START<br>GEN | NO<br>EXTEND | GCEN | PECEN |   | Rese | erved | 1 | EN |
| rw          |      |       | rw  | rw         | rw    | rw          | rw           | rw           | rw   | rw    |   |      |       |   | rw |

| Bit field | Name     | Description                                                                                         |
|-----------|----------|-----------------------------------------------------------------------------------------------------|
|           |          | Software reset                                                                                      |
|           |          | Make sure the I2C bus is idle before resetting this bit.                                            |
| 15        | SWRESET  | 0:I2C not reset;                                                                                    |
| 15        | SWRESEI  | 1:I2C reset.                                                                                        |
|           |          | Note: This bit can be used when the I2C_STS2.BUSY bit is set to 1 and no stop condition is detected |
|           |          | on the bus.                                                                                         |
| 14:13     | Reserved | Reserved, the reset value must be maintained                                                        |
|           |          | Packet error checking                                                                               |
|           |          | It can be set or cleared by software. It will be cleared by hardware when PEC has been transferred, |
| 10        | PEC      | or detect start or stop condition, or when I2C_CTRL1.EN=0.                                          |
| 12        | PEC      | 0: No PEC transfer                                                                                  |
|           |          | 1: PEC transfer.                                                                                    |
|           |          | Note: When arbitration is lost, the calculation of PEC is invalid.                                  |
|           |          | Acknowledge/PEC Position (for data reception)                                                       |
| 11        | ACKDOS   | It can be set or cleared by software. Or when I2C_CTRL1.EN=0, it will be cleared by hardware.       |
| 11        | ACKPOS   | 0: I2C_CTRL1.ACKEN bit determines whether to send an ACK to the byte currently being                |
|           |          | received; I2C_CTRL1.PEC bit indicates that the byte in the current shift register is PEC.           |



| Bit field | Name     | Description                                                                                         |
|-----------|----------|-----------------------------------------------------------------------------------------------------|
|           |          | 1: I2C_CTRL1.ACKEN bit etermines whether to send an ACK to the next received byte;                  |
|           |          | I2C_CTRL1.PEC bit indicates that the next byte received in the shift register is PEC.               |
|           |          | Note:                                                                                               |
|           |          | ACKPOS bit can only be used in 2-byte receiving configuration and must be configured before         |
|           |          | receiving data.                                                                                     |
|           |          | To NACK second byte, the I2C_CTRL1.ACKEN bit must be cleared after the I2C_STS1.ADDRF bit           |
|           |          | is cleared.                                                                                         |
|           |          | To detect the PEC of the second byte, the I2C_CTRL1.PEC bit must be set after the ACKPOS bit is     |
|           |          | configured and during the ADDR extend event.                                                        |
|           |          | Acknowledge enable                                                                                  |
|           |          | It can be set or cleared by software. Or when I2C_CTRL1.EN equals to 0, it will be cleared by       |
| 10        | ACKEN    | hardware.                                                                                           |
|           |          | 0: No acknowledge send;                                                                             |
|           |          | 1: Send an acknowledge after receiving a byte(matched address or data)                              |
|           |          | Stop generation                                                                                     |
|           |          | It can be set or cleared by software. Or it will be cleared by hardware when a stop condition is    |
|           |          | detected.                                                                                           |
|           |          | In the master mode:                                                                                 |
|           |          | 0: No stop condition generates;                                                                     |
| _         |          | 1: Generate a stop condition.                                                                       |
| 9         | STOPGEN  | In the slave mode:                                                                                  |
|           |          | 0: No stop condition generates;                                                                     |
|           |          | 1: Release SCL and SDA lines after the current byte.                                                |
|           |          | Note: When the STOPGEN, STARTGEN or PEC bit is set, the software should not take any write          |
|           |          | operation to I2C_CTRL1 until this bit is cleared by hardware. Otherwise, the STOPGEN,               |
|           |          | STARTGEN or PEC bits may be set twice.                                                              |
|           |          | Start generation                                                                                    |
|           |          | It can be set or cleared by software. Or it will be cleared by hardware when the start condition is |
| 8         | STARTGEN | transferred or I2C_CTRL1.EN=0.                                                                      |
|           |          | 0: No start condition generates;                                                                    |
|           |          | 1: Generate a start conditions.                                                                     |
|           |          | Clock extending disable (Slave mode)                                                                |
|           |          | This bit determines whether to pull SCL low as slave when the data is not ready(I2C_STS1.ADDRF      |
| 7         | NOEXTEND | or I2C_STS1.BSF flag is set) in slave mode, and is cleared by software reset                        |
|           |          | 0: Enable Clock extending.                                                                          |
|           |          | 1: Disable Clock extending.                                                                         |
|           |          | General call enable                                                                                 |
| 6         | GCEN     | 0: Disable General call. not acknowledge(NACK) the address 00h;                                     |
|           |          | 1: Enable General call. acknowledge(ACK) the address 00h.                                           |
|           |          | PEC enable                                                                                          |
| 5         | PECEN    | 0: Disable PEC module;                                                                              |
|           |          | 1: Enable PEC module.                                                                               |



| Bit field | Name     | Description                                                                                    |
|-----------|----------|------------------------------------------------------------------------------------------------|
| 4:1       | Reserved | Reserved, the reset value must be maintained.                                                  |
|           |          | I2C Peripheral enable                                                                          |
|           |          | 0: Disable I2C module;                                                                         |
| 0         | EN       | 1: Enable I2C module                                                                           |
| 0         | EIN      | Note: If this bit is cleared when communication is in progress, the I2C module is disabled and |
|           |          | returns to the idle state after the current communication ends, all bits will be cleared.      |
|           |          | In master mode, this bit must never be cleared until the communication has ended.              |

# 14.5.3 I2C Control register 2 (I2C\_CTRL2)

Address offset: 0x04

|   | 15 |             |          | 11 | 10           | 9            | 8            | 7    | 6    | 5 |       |         | 0    |
|---|----|-------------|----------|----|--------------|--------------|--------------|------|------|---|-------|---------|------|
|   |    | ,<br>,<br>, | Reserved |    | BUFINT<br>EN | EVTINT<br>EN | ERRINT<br>EN | Rese | rved |   | CLKFR | EQ[5:0] |      |
| _ |    |             |          |    | rw           | rw           | rw           |      |      |   | r     | w       | <br> |

| Bit field | Name     | Description                                                                      |
|-----------|----------|----------------------------------------------------------------------------------|
| 15:11     | Reserved | Reserved, the reset value must be maintained.                                    |
| 10        | BUFINTEN | Buffer interrupt enable                                                          |
|           |          | 0: When I2C_STS1.TXDATE=1 or I2C_STS1.RXDATNE=1, any interrupt is not generated. |
|           |          | 1: If I2C_CTRL2.EVTINTEN= 1, When I2C_STS1.TXDATE=1 or I2C_STS1.RXDATNE=         |
|           |          | 1, interrupt will be generated.                                                  |
| 9         | EVTINTEN | Event interrupt enable                                                           |
|           |          | 0: Disable event interrupt;                                                      |
|           |          | 1: Enable event interrupt                                                        |
|           |          | This interrupt is generated when:                                                |
|           |          | I2C_STS1.STARTBF = 1 (Master)                                                    |
|           |          | I2C_STS1.ADDR $F = 1$ (Master/Slave)                                             |
|           |          | $I2C\_STS1.ADD10F = 1$ (Master)                                                  |
|           |          | $I2C\_STS1.STOPF = 1$ (Slave)                                                    |
|           |          | I2C_STS1.BSF = 1 with no I2C_STS1.TXDATE or I2C_STS1.RXDATNE event               |
|           |          | I2C_STS1.TXDATE = 1 when I2C_CTRL2.BUFINTEN = 1                                  |
|           |          | I2C_STS1.RXDATNE = 1 when I2C_CTRL2.BUFINTEN = 1                                 |
| 8         | ERRINTEN | Error interrupt enable                                                           |
|           |          | 0: Disable error interrupt;                                                      |
|           |          | 1: Enable error interrupt.                                                       |
|           |          | This interrupt is generated when:                                                |
|           |          | $I2C\_STS1.BUSERR = 1;$                                                          |
|           |          | I2C_STS1.ARLOST = 1;                                                             |
|           |          | I2C_STS1.ACKFAIL = 1;                                                            |
|           |          | I2C_STS1.OVERRUN = 1;                                                            |
|           |          | $I2C\_STS1.PECERR = 1;$                                                          |





| Bit field | Name         | Description                                                                     |
|-----------|--------------|---------------------------------------------------------------------------------|
| 7:6       | Reserved     | Reserved, the reset value must be maintained.                                   |
| 5:0       | CLKFREQ[5:0] | I2C Peripheral clock frequency                                                  |
|           |              | CLKFREQ[5:0] should be the APB clock frequency to generate the correct timming. |
|           |              | 000000: Disable                                                                 |
|           |              | 000001: Disable                                                                 |
|           |              | 000010: 2MHz                                                                    |
|           |              | 000011: 3MHz                                                                    |
|           |              |                                                                                 |
|           |              | 110000: 48MHz                                                                   |
|           |              | 110001~111111: Disable.                                                         |

## 14.5.4 I2C Own address register 1 (I2C\_OADDR1)

### Address offset: 0x08

### Reset value: 0x0000

| 15           | 14 |          | 10 | 9   | 8      | 7 |   |           |      |   | 1 | 0     |
|--------------|----|----------|----|-----|--------|---|---|-----------|------|---|---|-------|
| ADDR<br>MODE |    | Reserved |    | ADD | R[9:8] |   | 1 | ADDR[7:1] | <br> | 1 |   | ADDR0 |
| rw           |    |          |    | r   | w      |   |   | rw        |      |   |   | rw    |

| Bit field | Name      | Description                                       |  |  |  |  |  |  |  |
|-----------|-----------|---------------------------------------------------|--|--|--|--|--|--|--|
| 15        | ADDRMODE  | Addressing mode (slave mode)                      |  |  |  |  |  |  |  |
|           |           | 0: 7-bit slave address                            |  |  |  |  |  |  |  |
|           |           | 1: 10-bit slave address                           |  |  |  |  |  |  |  |
| 14        | Reserved  | st always be kept as' 1' by the software.         |  |  |  |  |  |  |  |
| 13:10     | Reserved  | served, the reset value must be maintained.       |  |  |  |  |  |  |  |
| 9:8       | ADDR[9:8] | Interface address                                 |  |  |  |  |  |  |  |
|           |           | 9~8 bits of the address.                          |  |  |  |  |  |  |  |
|           |           | Note: don't care these bits in 7-bit address mode |  |  |  |  |  |  |  |
| 7:1       | ADDR[7:1] | Interface address                                 |  |  |  |  |  |  |  |
|           |           | 7~1 bits of the address.                          |  |  |  |  |  |  |  |
| 0         | ADDR0     | Interface address                                 |  |  |  |  |  |  |  |
|           |           | 0 bit of the address.                             |  |  |  |  |  |  |  |
|           |           | Note: don't care these bits in 7-bit address mode |  |  |  |  |  |  |  |

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

### Address offset: 0x0C

| 15 |   |     |       |   | 8 | 7 |   |         |                |        |   | 1 | 0      |
|----|---|-----|-------|---|---|---|---|---------|----------------|--------|---|---|--------|
|    | 1 | Res | erved | I | 1 |   | 1 |         | 1<br>ADDR2[7:1 | 1      | 1 |   | DUALEN |
|    |   | 1   |       |   |   |   |   | · · · · |                | .]<br> |   |   | DOMEEN |
|    |   |     |       |   |   |   |   |         | rw             |        |   |   | rw     |



| Bit field | Name       | Description                                                         |
|-----------|------------|---------------------------------------------------------------------|
| 15:8      | Reserved   | Reserved, the reset value must be maintained.                       |
| 7:1       | ADDR2[7:1] | Interface address                                                   |
|           |            | 7~1 bits of address in dual address mode.                           |
| 0         | DUALEN     | Dual addressing mode enable                                         |
|           |            | 0: Disable dual address mode, only OADDR1 is recognized;            |
|           |            | 1: Enable dual address mode, both OADDR1 and OADDR2 are recognized. |
|           |            | Note: Valid only for 7-bit address mode                             |

# 14.5.6 I2C Data register (I2C\_DAT)

### Address offset: 0x10

### Reset value: 0x0000

| 15 |     |        |     |   | 8 | 7 |   |   |      |        |   |   | 0 |
|----|-----|--------|-----|---|---|---|---|---|------|--------|---|---|---|
|    | 1 1 | Reserv | ved | 1 | 1 |   | I | 1 | DATA | .[7:0] | 1 | 1 |   |
|    |     | I      | I   | 1 | I |   |   |   |      |        | I | 1 |   |
|    |     |        |     |   |   |   |   |   | rv   | v      |   |   |   |

| Bit field | Name      | Description                                                                                          |
|-----------|-----------|------------------------------------------------------------------------------------------------------|
| 15:8      | Reserved  | Reserved, the reset value must be maintained.                                                        |
| 7:0       | DATA[7:0] | 8-bit data register                                                                                  |
|           |           | Send or receive data buffer.                                                                         |
|           |           | Note: In the slave mode, the address will not be copied into the data register;                      |
|           |           | <i>Note: if</i> I2C_STS1. <i>TXDATE</i> =0, <i>data can still be written into the data register;</i> |
|           |           | Note: If the ARLOST event occurs when processing the ACK pulse, the received byte will not be        |
|           |           | copied into the data register, so it cannot be read.                                                 |

## 14.5.7 I2C Status register 1 (I2C\_STS1)

### Address offset: 0x14

| 15 |          | 13 | 12         | 11          | 10          | 9          | 8          | 7      | 6           | 5        | 4     | 3       | 2   | 1     | 0           |
|----|----------|----|------------|-------------|-------------|------------|------------|--------|-------------|----------|-------|---------|-----|-------|-------------|
|    | Reserved |    | PEC<br>ERR | OVER<br>RUN | ACK<br>FAIL | AR<br>LOST | BUS<br>ERR | TXDATE | RXDAT<br>NE | Reserved | STOPF | ADDR10F | BSF | ADDRF | START<br>BF |
|    |          |    | rc_w0      | rc_w0       | rc_w0       | rc_w0      | rc_w0      | r      | r           |          | r     | r       | r   | r     | r           |

| Bit field | Name     | Description                                                                                  |
|-----------|----------|----------------------------------------------------------------------------------------------|
| 15:13     | Reserved | Reserved, the reset value must be maintained.                                                |
| 12        | PECERR   | PEC Error in reception                                                                       |
|           |          | Writing '0' to this bit by software can clear it, or it is cleared by hardware when          |
|           |          | I2C_CTRL1.EN=0.                                                                              |
|           |          | 0: No PEC error: receiver will returns ACK (if the I2C_CTRL1.ACKEN bit is enabled)           |
|           |          | 1: PEC error: receiver will returns NACK (It doesn't matter if I2C_CTRL1.ACKEN is enabled or |
|           |          | not)                                                                                         |
| 11        | OVERRUN  | Overrun/Underrun                                                                             |



| Bit field | Name    | Description                                                                                          |
|-----------|---------|------------------------------------------------------------------------------------------------------|
|           |         | Writing '0' to this bit by software can clear it, or it is cleared by hardware when                  |
|           |         | I2C_CTRL1.EN=0.                                                                                      |
|           |         | 0: No Overrun/Underrun                                                                               |
|           |         | 1: Overrun/Underrun                                                                                  |
|           |         | Set by hardware in slave mode when I2C_CTRL1.NOEXTEND=1, and when receiving a new                    |
|           |         | byte in receiving mode, if the data within DAT register has not been read yet, over-run occurs, the  |
|           |         | new received byte will be lost. When transmitting a new byte in transmit mode, but there is not      |
|           |         | new data that has not been written in DAT register, under-run occurs which leads that the same       |
|           |         | byte will be send twice.                                                                             |
| 10        | ACKFAIL | Acknowledge failure                                                                                  |
|           |         | Writing '0' to this bit by software can clear it, or it is cleared by hardware when                  |
|           |         | I2C_CTRL1.EN=0.                                                                                      |
|           |         | 0: No acknowledge failed;                                                                            |
|           |         | 1: Acknowledge failed.                                                                               |
| 9         | ARLOST  | Arbitration lost (master mode)                                                                       |
|           |         | Writing '0' to this bit by software can clear it, or it is cleared by hardware when                  |
|           |         | I2C_CTRL1.EN=0.                                                                                      |
|           |         | 0: No arbitration lost;                                                                              |
|           |         | 1: Arbitration lost.                                                                                 |
|           |         | When the interface loses control of the bus, the hardware will set this bit to '1', and the I2C      |
|           |         | interface will automatically switch back to slave mode (I2C_STS2.MSMODE=0).                          |
| 8         | BUSERR  | Bus error                                                                                            |
|           |         | Writing '0' to this bit by software can clear it, or it is cleared by hardware when                  |
|           |         | I2C_CTRL1.EN=0.                                                                                      |
|           |         | 0: No start or stop condition error                                                                  |
|           |         | 1: Start or stop condition error                                                                     |
| 7         | TXDATE  | Data register empty (transmitters)                                                                   |
|           |         | Writing data to DAT register by software can clear this bit; Or after a start or stop condition      |
|           |         | occurs, or automatically cleared by hardware when I2C_CTRL1.EN=0.                                    |
|           |         | 0: Data register is not empty;                                                                       |
|           |         | 1: Data register is empty.                                                                           |
|           |         | When sending data, this bit is set to' 1' when the data register is empty, and it is not set at the  |
|           |         | address sending stage.                                                                               |
|           |         | If a NACK is received, or the next byte to be sent is PEC(I2C_CTRL1.PEC=1), this bit will not        |
|           |         | be set.                                                                                              |
|           |         | Note: After the first data to be sent is written, or data is written when BSF is set, the TXDATE bit |
|           |         | cannot be cleared, because the data register is still empty.                                         |
| 6         | RXDATNE | Data register not empty(receivers)                                                                   |
| -         |         | This bit is cleared by software reading and writing to the data register, or cleared by hardware     |
|           |         | when I2C_CTRL1.EN=0.                                                                                 |
|           |         | 0: Data register is empty;                                                                           |
|           |         | 1: Data register is on empty.                                                                        |



| Bit field | Name     | Description                                                                                             |
|-----------|----------|---------------------------------------------------------------------------------------------------------|
|           |          | During receiving data, this bit is set to' 1' when the data register is not empty, and it is not set at |
|           |          | the address receiving stage.                                                                            |
|           |          | RXDATNE is not set when the ARLOST event occurs.                                                        |
|           |          | Note: When BSF is set, the RXDATNE bit cannot be cleared when reading data, because the data            |
|           |          | register is still full.                                                                                 |
| 5         | Reserved | Reserved, the reset value must be maintained.                                                           |
| 4         | STOPF    | Stop detection (slave mode)                                                                             |
|           |          | After the software reads the STS1 register, the operation of writing to the CTRL1 register will         |
|           |          | clear this bit, or when I2C_CTRL1.EN=0, the hardware will clear this bit.                               |
|           |          | 0: No stop condition is detected;                                                                       |
|           |          | 1: Stop condition is detected.                                                                          |
|           |          | After a ACK, the hardware sets this bit to' 1' when the slave device detects a stop condition on        |
|           |          | the bus.                                                                                                |
|           |          | Note: I2C_STS1.STOPF bit is not set after receiving NACK.                                               |
| 3         | ADDR10F  | 10-bit header sent (Master mode)                                                                        |
|           |          | After the software reads the STS1 register, the operation of writing to the CTRL1 register will         |
|           |          | clear this bit, or when I2C_CTRL1.EN=0, the hardware will clear this bit.                               |
|           |          | 0: No ADD10F event;                                                                                     |
|           |          | 1: Master has sent the first address byte.                                                              |
|           |          | In 10-bit address mode, when the master device has sent the first byte, the hardware sets this bit      |
|           |          | to' 1'.                                                                                                 |
|           |          | Note: After receiving a NACK, the I2C_STS1.ADDR10F bit is not set.                                      |
| 2         | BSF      | Byte transfer finished                                                                                  |
|           |          | After the software reads the STS1 register, reading or writing the data register will clear this bit;   |
|           |          | Or after sending a start or stop condition in transfer, or when I2C_CTRL1.EN=0, this bit is             |
|           |          | cleared by hardware.                                                                                    |
|           |          | 0: Byte transfer does not finish.                                                                       |
|           |          | 1: Byte transfer finished.                                                                              |
|           |          | When I2C_CTRL1.NOEXTEND =0, the hardware sets this bit to' 1' in the following cases:                   |
|           |          | In receiving mode, when a new byte (including ACK pulse) is received and the data register has          |
|           |          | not been read (I2C_STS1.RXDATNE=1).                                                                     |
|           |          | In sending mode, when a new data is to be transmitted and the data register has not been written        |
|           |          | the new data (I2C_STS1.TXDATE=1).                                                                       |
|           |          | Note: After receiving a NACK, the BSF bit will not be set.                                              |
|           |          | If the next byte to be transferred is PEC (I2C _STS2.TRF is' 1' and I2C_CTRL1.PEC is' 1'), the          |
|           |          | BSF bit will not be set.                                                                                |
| 1         | ADDRF    | Address sent (master mode) / matched (slave mode)                                                       |
|           |          | After the STS1 register is read by software, reading the STS2 register will clear this bit, or when     |
|           |          | I2C_CTRL1.EN=0, it will be cleared by hardware.                                                         |
|           |          | 0: Address mismatch or no address received(slave mode) or Address sending did not end(master            |
|           |          | mode);                                                                                                  |
|           |          | 1: Received addresses matched(slave mode) or Address sending ends(master mode)                          |





| Bit field | Name    | Description                                                                                             |
|-----------|---------|---------------------------------------------------------------------------------------------------------|
|           |         | In master mode:                                                                                         |
|           |         | In 7-bit address mode, this bit is set to' 1' after receiving the ACK of the address. In 10-bit address |
|           |         | mode, this bit is set to' 1' after receiving the ACK of the second byte of the address.                 |
|           |         | In slave mode:                                                                                          |
|           |         | Hardware sets this bit to' 1' (when the corresponding setting is enabled) when the received slave       |
|           |         | address matches the content in the OADDR register, or a general call is recognized.                     |
|           |         | Note: After receiving NACK, the I2C_STS1.ADDRF bit will not be set.                                     |
| 0         | STARTBF | Start bit (Master mode)                                                                                 |
|           |         | After the STS1 register is read by software, writing to the data register will clear this bit, or when  |
|           |         | I2C_CTRL1.EN=0, the hardware will clear this bit.                                                       |
|           |         | 0: Start condition was not sent;                                                                        |
|           |         | 1: Start condition has been sent.                                                                       |
|           |         | This bit is set to' 1' when the start condition is sent.                                                |

# 14.5.8 I2C Status register 2 (I2C\_STS2)

Address offset: 0x18

| 15 |   |      |        |   |   | 8 | 7            | 6    | 5     | 4             | 3        | 2   | 1    | 0          |
|----|---|------|--------|---|---|---|--------------|------|-------|---------------|----------|-----|------|------------|
|    | 1 | PECV | L[7:0] | 1 | 1 | 1 | DUAL<br>FLAG | Rese | erved | GCALL<br>ADDR | Reserved | TRF | BUSY | MS<br>MODE |
|    |   | :    | r      |   |   |   | r            |      |       | r             |          | r   | r    | r          |

| Bit field | Name        | Description                                                                                   |
|-----------|-------------|-----------------------------------------------------------------------------------------------|
| 15:8      | PECVAL[7:0] | Packet error checking register                                                                |
|           |             | Stores the internal PEC value When I2C_CTRL1.PECEN =1.                                        |
| 7         | DUALFLAG    | Dual flag(Slave mode)                                                                         |
|           |             | Hardware clears this bit when a stop condition or a repeated start condition is generated, or |
|           |             | when I2C_CTRL1.EN=0.                                                                          |
|           |             | 0: Received address matches the content in OADDR1;                                            |
|           |             | 1: Received address matches the content in OADDR2.                                            |
| 6:5       | Reserved    | Reserved, the reset value must be maintained.                                                 |
| 4         | GCALLADDR   | General call address(Slave mode)                                                              |
|           |             | Hardware clears this bit when a stop condition or a repeated start condition is generated, or |
|           |             | when I2C_CTRL1.EN=0.                                                                          |
|           |             | 0: No general call address was received;                                                      |
|           |             | 1: when I2C_CTRL1.GCEN=1, general call address was received.                                  |
| 3         | Reserved    | Reserved, the reset value must be maintained.                                                 |
| 2         | TRF         | Transmitter/receiver                                                                          |
|           |             | After detecting the stop condition (I2C_STS1.STOPF=1), repeated start condition or bus        |
|           |             | arbitration loss (I2C_STS1.ARLOST=1), or when I2C_CTRL1.EN=0, the hardware clears it.         |
|           |             | 0: Data receiving mode                                                                        |
|           |             | 1: Data transmission mode;                                                                    |



| Bit field | Name   | Description                                                                                     |
|-----------|--------|-------------------------------------------------------------------------------------------------|
|           |        | At the end of the whole address transmission stage, this bit is set according to the R/W bit of |
|           |        | the address byte.                                                                               |
| 1         | BUSY   | Bus busy                                                                                        |
|           |        | Hardware clears this bit when a stop condition is detected.                                     |
|           |        | 0: No data communication on the bus;                                                            |
|           |        | 1: Data communication on the bus.                                                               |
|           |        | When detecting that SDA or SCL is low level, the hardware sets this bit to' 1';                 |
|           |        | Note: This bit indicates the bus communication currently in progress, and this information is   |
|           |        | still updated when the interface is disabled (I2C_CTRL1.EN=0).                                  |
| 0         | MSMODE | Master/slave mode                                                                               |
|           |        | Hardware clears this bit when a stop condition is detected on the bus, arbitration is lost      |
|           |        | (I2C_STS1.ARLOST=1), or when I2C_CTRL1.EN=0.                                                    |
|           |        | 0: In slave mode;                                                                               |
|           |        | 1: In master mode.                                                                              |
|           |        | When the interface is in the master mode (I2C_STS1.STARTBF=1), the hardware sets this bit;      |

# 14.5.9 I2C Clock control register (I2C\_CLKCTRL)

### Address offset: 0x1c

Reset value: 0x0000

## *Note: The CLKCTRL register can only be set when* $I^2C$ *is turned off* ( $I2C\_CTRL1.EN=0$ )

| 15     | 14   | 13       | 12 | 11 |               |  |  |  |    |   |   |  |   |  | 0 |
|--------|------|----------|----|----|---------------|--|--|--|----|---|---|--|---|--|---|
| FSMODE | DUTY | Reserved |    |    | CLKCTRL[11:0] |  |  |  |    |   |   |  | 1 |  |   |
|        |      |          | I  |    | I             |  |  |  | L  |   | 1 |  | 1 |  |   |
| rw     | rw   |          |    |    |               |  |  |  | 17 | w |   |  |   |  |   |

| Bit field | Name          | Description                                                              |  |  |  |  |  |  |
|-----------|---------------|--------------------------------------------------------------------------|--|--|--|--|--|--|
| 15        | FSMODE        | I2C mode selection                                                       |  |  |  |  |  |  |
|           |               | 0: I2C in standard mode (duty cycle default 1/1);                        |  |  |  |  |  |  |
|           |               | 1: I2C in fast mode (duty cycle configurable).                           |  |  |  |  |  |  |
| 14        | DUTY          | Duty cycle in fast mode                                                  |  |  |  |  |  |  |
|           |               | 0: Tlow/Thigh = 2;                                                       |  |  |  |  |  |  |
|           |               | 1: Tlow/Thigh = 16/9                                                     |  |  |  |  |  |  |
| 13:12     | Reserved      | Reserved, the reset value must be maintained.                            |  |  |  |  |  |  |
| 11:0      | CLKCTRL[11:0] | Clock control register in Fast/Standard mode (Master mode)               |  |  |  |  |  |  |
|           |               | This division factor is used to set the SCL clock in the master mode.    |  |  |  |  |  |  |
|           |               | If duty cycle = $Tlow/Thigh = 1/1$ :                                     |  |  |  |  |  |  |
|           |               | $CLKCTRL = f_{PCLK}(Hz)/100000/2$                                        |  |  |  |  |  |  |
|           |               | Thow = CLKCTRL $\times$ TPCLK                                            |  |  |  |  |  |  |
|           |               | Thigh = CLKCTRL $\times$ T <sub>PCLK</sub>                               |  |  |  |  |  |  |
|           |               | If duty cycle = $Tlow/Thigh = 2/1$ :                                     |  |  |  |  |  |  |
|           |               | $CLKCTRL = f_{PCLK}(Hz)/100000/3$                                        |  |  |  |  |  |  |
|           |               | The equation $T_{\text{PCLK}} = 2 \times CLKCTRL \times T_{\text{PCLK}}$ |  |  |  |  |  |  |





| Bit field | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |      | Thigh = CLKCTRL×T <sub>PCLK</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           |      | If duty cycle = $Tlow/Thigh = 16/9$ :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|           |      | $CLKCTRL = f_{PCLK}(Hz)/100000/25$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           |      | The set of |
|           |      | Thigh = 9 ×CLKCTRL ×T <sub>PCLK</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|           |      | For example, if $f_{PCLK}(Hz) = 8MHz$ , duty cycle = 1/1, CLKCTRL = $8000000/100000/2 = 0x28$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           |      | Note: 1. The minimum setting value is 0x04 in standard mode and 0x01 in fast mode;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           |      | 2. $T_{high} = T_{r(SCL)} + T_{w(SCLH)}$ . See the definitions of these parameters in the data sheet for details.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           |      | 3. $T_{low} = T_{f(SCL)} + T_{w(SCLL)}$ , see the definitions of these parameters in the data sheet for details;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

# 14.5.10 I2C Rise time register (I2C\_TMRISE)

Address offset: 0x20

Reset value: 0x0002

| 15 |          |     |  |  |  |   |  | 6 | 5 |   |             |   |     | 0 |  |
|----|----------|-----|--|--|--|---|--|---|---|---|-------------|---|-----|---|--|
|    | 1        |     |  |  |  | 1 |  |   |   | 1 |             |   |     |   |  |
|    | Reserved |     |  |  |  |   |  |   |   |   | TMRISE[5:0] |   |     |   |  |
|    |          | 1 1 |  |  |  | 1 |  | 1 |   |   |             | 1 | 1 1 |   |  |
|    |          |     |  |  |  |   |  |   |   |   |             |   |     |   |  |
|    |          |     |  |  |  |   |  |   |   |   | r           | W |     |   |  |

| Bit field | Name        | Description                                                                                                       |
|-----------|-------------|-------------------------------------------------------------------------------------------------------------------|
| 15:6      | Reserved    | Reserved, the reset value must be maintained.                                                                     |
| 5:0       | TMRISE[5:0] | Maximum rise time in fast/standard mode (master mode).                                                            |
|           |             | These bits must be set to the maximum SCL rising time given in the I2C bus specification, and                     |
|           |             | incremented step is 1.                                                                                            |
|           |             | For example, the maximum allowable SCL rise time in standard mode is 1000ns. if the value in                      |
|           |             | I2C_CTRL2.CLKFREQ [5:0] is equal to 0x08(8MHz) and TPCLK=125ns ,09h(1000ns/125 ns + 1)                            |
|           |             | must be written in TMRISE[5:0].                                                                                   |
|           |             | If the result is not an integer, write the integer part to TMRISE[5:0] to ensure the t <sub>HIGH</sub> parameter. |
|           |             | Note: TMRISE[5:0] can only be set when I2C is disabled (I2C_CTRL1.EN=0).                                          |

# 14.5.11 I2C Filter control register (I2C\_GFLTRCTRL)

Address offset: 0x24



| 15:14 | Reserved | Reserved                  |  |  |  |  |  |
|-------|----------|---------------------------|--|--|--|--|--|
| 13    | SCLAFENN | SCL analog filter enable. |  |  |  |  |  |
|       |          | 0: Enable                 |  |  |  |  |  |
|       |          | 1: Disable                |  |  |  |  |  |



| Bit field | Name         | Description                                        |
|-----------|--------------|----------------------------------------------------|
| 12:11     | SCLAFW[1:0]  | SCL analog filter width selection                  |
|           |              | 00: 5ns                                            |
|           |              | 01: 15ns                                           |
|           |              | 10: 25ns                                           |
|           |              | 11: 35ns                                           |
| 10        | SDAAFENN     | SDA analog filter enable                           |
|           |              | 0: Enable                                          |
|           |              | 1: Disable                                         |
| 9:8       | SDAAFW[1:0]  | SDA analog filter width selection                  |
|           |              | 00: 5ns                                            |
|           |              | 01: 15ns                                           |
|           |              | 10: 25ns                                           |
|           |              | 11: 35ns                                           |
| 7:4       | SCLDFW[3:0]  | SCL digital filter width selection                 |
|           | SCLDI W[5.0] | 0000: Disable SCL digital filter                   |
|           |              | Others: Filter width is SCLDFW * TPCLK             |
| 3:0       | SDADFW[3:0]  | SDA digital filter width selection                 |
|           |              | 0000: Disable SDA digital filter                   |
|           |              | Others: Filter width is SDADFW * T <sub>PCLK</sub> |

# 14.5.12 **I2C master receive byte register (I2C\_BYTENUM)**

Address offset: 0x28

|   | 15            | 14     | 13 |               |  |  |  |  |   |   |  | <br> | <br> | 0 |
|---|---------------|--------|----|---------------|--|--|--|--|---|---|--|------|------|---|
|   | BYTE<br>NUMEN | RXFSEL |    | BYTENUM[13:0] |  |  |  |  |   |   |  |      |      |   |
| , | rw            | rw     |    |               |  |  |  |  | r | N |  |      |      |   |

| Bit field | Name      | Description                                                                              |
|-----------|-----------|------------------------------------------------------------------------------------------|
| 15        | BYTENUMEN | Master receive byte control enable                                                       |
|           |           | 0: Disable                                                                               |
|           |           | 1: Enable                                                                                |
| 14        | RXFSEL    | Receive end send condition selection                                                     |
|           |           | 0: master sends a STOP condition after receiving all bytes                               |
|           |           | 1: master sends a START condition after receiving all bytes                              |
| 13:0      | BYTENUM   | Master receives bytes configuration                                                      |
|           |           | Note: If you need to reconfigure BYTENUM after receiving all bytes, you need to wait for |
|           |           | I2C_STS2.BUSY is 0 and re-enabled I2C_CTRL1.ACKEN                                        |



# 15 Universal asynchronous receiver transmitter (UART)

# **15.1 Introduction**

UART is a full-duplex universal asynchronous serial transceiver module. This interface is a highly flexible serial communication device that can perform full-duplex data exchange with external devices.

The UART has programmable transmit and receive baud rates. It also supports single-wire half-duplex communication and Multipprocessor communication.

# **15.2 Main features**

- Full-duplex asynchronous communication
- Supports NRZ standard format
- Supports single-wire half-duplex communication
- Configurable baud rate
- Support serial data frame structure with 8 or 9 data bits, 1 or 2 stop bits
- Generation and checking of supported parity bits
- Support multi-processor communication mode, can enter mute mode, wake up by idle detection or address mark detection
- Support data overflow error detection, frame error detection, noise error detection, parity error detection
- 8 interrupt requests:
  - ♦ Transmit data register empty
  - ♦ Transmit complete
  - ♦ Receive data register full
  - ♦ Idle line detected
  - ♦ Data overflow detected
  - ♦ Frame error
  - $\diamond$  Noise error
  - ♦ Parity error



## 15.3 Functional block diagram



Figure 15-1 UART block diagram

## **15.4 Function description**

As shown in the Figure 15-1, the bidirectional communication of any UART needs to use the RX and TX pins to connect to external devices. Among them, TX is the output pin for serial data transmission. When the transmitter is active and not sending data, the TX pin is pulled high. When the transmitter is inactive, the TX pin reverts to the I/O



port configuration. RX is an input pin for serial data reception, data is recovered by oversampling technique.

The data packets of serial communication are transmitted from the sending device to the RX interface of the receiving device through its own TX interface, and the bus is in an idle state before sending or receiving. Frame format is: 1 start bit + 8 or 9 data bits (least significant bit first) + 1 parity bit (optional) + 1 or 2 stop bit.

Use the fractional baud rate generator to configure transmit and receive baud rates.

## 15.4.1 UART frame format

The start bit of the data frame is low.

The word length can be selected as 8 or 9 bits by programming the UART\_CTRL1.WL bit, least significant bit first.

The stop bit of the data frame is high.

An idle frame is a complete data frame consisting of '1's, including the start bit.

A break frame is a complete data frame consisting of '0's, including the stop bit. At the end of the break frame, the transmitter inserts 1 or 2 stop bits ('1') to acknowledge the start bit.



#### Figure 15-2 Word length = 8 setting

#### Figure 15-3 Word length = 9 setting

|       |                                   | 9-b  | oit word | d lengt | h , 1 st | op bit |      |      |      |        |             | I            |       |
|-------|-----------------------------------|------|----------|---------|----------|--------|------|------|------|--------|-------------|--------------|-------|
| Clock | <br> <br>                         |      |          |         |          |        |      |      |      | **     | <br>        | <br> <br>    |       |
|       | Data frame bit8 can be the parity |      |          |         |          |        |      |      |      | ty bit | Start       | Data frame   |       |
|       | Stat<br>bit                       | bit0 | bit1     | bit2    | bit3     | bit4   | bit5 | bit6 | bit7 | bit8   | Stop<br>bit | bit          |       |
|       | Idle frame                        |      |          |         |          |        |      |      |      |        |             | Start<br>bit |       |
|       |                                   |      |          |         |          |        |      |      |      |        |             | Stop         | Start |
|       | I                                 |      | E        | Break f | rame     |        |      |      |      |        |             | bit          |       |



## 15.4.2 Transmitter

After the transmitter is enabled, the data entered into the transmit shift register is sent out through the TX pin.

## 15.4.2.1 **Idle frame**

Setting UART\_CTRL1.TXEN will cause the UART to transmit an idle frame before the first data frame.

## 15.4.2.2 Character send

Idle frames are followed by characters sent. Each character is preceded by a low start bit. The transmitter sends 8-bit or 9-bit data according to the configuration of the data bit length, with the least significant bit first. If UART\_CTRL1.TXEN is reset during a data transfer, it will cause the baud rate counter to stop counting and the data being transferred will be corrupted.

### 15.4.2.3 **Stop bit**

The characters are followed by stop bits, the number of which can be configured by setting UART\_CTRL2. STPB[1:0] bits.

| UART_CTRL2.STPB[1:0] | Stop bit length (bits) | functional description                              |  |  |  |  |  |  |
|----------------------|------------------------|-----------------------------------------------------|--|--|--|--|--|--|
| 00                   | 1                      | default                                             |  |  |  |  |  |  |
| 10                   | 2                      | General UART mode, single-wire mode and modem mode. |  |  |  |  |  |  |

#### Table 15-1 Stop bit configuration

#### Figure 15-4 Stop bit configuration



## 15.4.2.4 Break frame

Use UART\_CTRL1.SDBRK to send the break frame. When there is 8-bit data, the break frame consists of 10 bits of low level, followed by a stop bit; when there is 9-bit data, the break frame consists of 11 bits of low level, followed by a stop bit.



After the break frame is sent, UART\_CTRL1.SDBRK is cleared by hardware, and the stop bit of the break frame is being sent. Therefore, to send a second break frame, UART\_CTRL1.SDBRK should be set after the stop bit of the previous break frame has been sent.

If software resets the UART\_CTRL1.SDBRK bit before starting to send the break frame, the break frame will not be sent.

### 15.4.2.5 **Transmitter process**

- 1. Enable UART\_CTRL1.UEN to activate UART;
- 2. Configure the transmitter's baud rate, data bit length, parity bit (optional), the number of stop bits;
- 3. Activate the transmitter (UART\_CTRL1.TXEN);
- 4. Write each data to be sent to the UART\_DAT register through the CPU, and the write operation to the UART\_DAT register will clear UART\_STS.TXDE;
- 5. After writing the last data word to the UART\_DAT register, wait for UART\_STS.TXC =1, which indicates the end of the transmission of the last data frame.

### 15.4.2.6 Single byte communication

Writing to the UART\_DAT register clears the UART\_STS.TXDE bit.

The UART\_STS.TXDE bit is set by hardware when the data in the TDR register is transferred to the transmit shift register (indicating that data is being transmitted). An interrupt will be generated if UART\_CTRL1.TXDEIEN is set. At this point, the next data can be write to the UART\_DAT register because the TDR register has been cleared and will not overwrite the previous data.

Write operation to UART\_DAT register:

- When the transmit shift register is not sending data and is in an idle state, the data is directly put into the shift register for transmission, and the UART\_STS.TXDE bit is set by hardware;
- When the transmit shift register is sending data, the data is stored in the TDR register, and after the current transmission is completed, the data is put into the shift register.

When a frame containing data is sent and UART\_STS.TXDE=1, the UART\_STS.TXC bit is set to '1' by hardware. An interrupt is generated if UART\_CTRL1.TXCIEN is '1'.UART\_STS.TXC bit is cleared by a software sequence (read UART\_STS register first, then write UART\_DAT register).





#### Figure 15-5 TXC/TXDE changes during transmission

## 15.4.3 Receiver

### 15.4.3.1 Start bit detection

When the received sampling sequence is: 1 1 1 0 X 0 X 0 X 0 0 0 0, it is considered that a start bit is detected.

The samples at the 3rd, 5th, and 7th bits, and the samples at the 8th, 9th, and 10th bits are all '0' (that is, 6 '0'), then confirm the receipt of the start bit, the UART\_STS.RXDNE flag bit is set, and if UART\_CTRL1.RXDNEIEN=1, an interruption occurs, but it will not set the NEF noise flag.

The samples of the 3rd, 5th, and 7th bits have two '0' points, and at the same time, the samples of the 8th, 9th, and 10th bits have two '0' points, then it is confirmed that the start bit is received, but it will be set bit NEF noise flag.

The samples of the 3rd, 5th, and 7th bits have two '0' points, and at the same time, the samples of the 8th, 9th, and 10th bits have three '0' points, then the start bit is confirmed, but it will be set NEF noise flag.

The samples of the 3rd, 5th, and 7th bits have three '0' points, and at the same time, the samples of the 8th, 9th, and 10th bits have two '0' points, then the start bit is confirmed, but it will be set NEF noise flag.

If the sampling values in the 3rd, 5th, 7th, 8th, 9th and 10th bits cannot meet the above four requirements, the UART receiver thinks that it has not received the correct start bit, and will exit the start bit detection and return to idle state and wait for falling edge.



#### Figure 15-6 Start bit detection



## 15.4.3.2 **Stop bit description**

During data reception, the number of data stop bits can be configured by the UART\_CTRL2.STPB[1:0] bits. In normal mode, 1 or 2 stop bits can be selected.

- 1. **1 stop bit:** the sampling of 1 stop bit is carried out through three points, and the 8th, 9th and 10th sampling bits are selected.
- 2. **2 stop bits:** the sampling of 2 stop bits is completed at the 8th, 9th and 10th sampling points of the first stop position. If a frame error is detected during the first stop bit, the frame error flag is set. The second stop bit does not detect frame error. The UART\_STS.RXNE flag will be set at the end of the first stop bit.

### 15.4.3.3 **Receiver process**

- 1. Enable UART\_CTRL1.UEN to activate UART;
- 2. Configure the receiver's baud rate, data bit length, parity bit (optional), stop bit number;
- 3. Activate the receiver (UART\_CTRL1.RXEN) and start looking for the start bit;
- 4. The receiver receives 8-bit or 9-bit data according to the configuration of the data bit length, and the least significant bit of the data is first shifted from the RX pin into the receive shift register;
- 5. When the data of the received shift register is moved to the RDR register, UART\_STS.RXDNE is set, and the data can be read out. If UART\_CTRL1.RXDNEIEN is 1, an interrupt will be generated;
- 6. When an overflow error, noise error, or frame error is detected in the received frame, the corresponding error flag status bit will be set. If UART\_CTRL1.RXEN is reset during data transmission, the data being received will be lost;



### 7. UART\_STS.RXDNE is set after receiving data, and a read operation to UART\_DAT can clear this bit:

During single-buffer communication, it is cleared by software reading the UART\_DAT register.

## 15.4.3.4 Idle frame detection

When an idle frame is detected, UART\_STS.IDLEF sets to 1. An interrupt is generated if UART\_CTRL1.IDLEIEN is '1'. UART\_STS.IDLEF bit is cleared by a software sequence (read UART\_STS register first, then read UART\_DAT register).

## 15.4.3.5 Break frame detection

The frame error flag(UART\_STS.FEF) is set by hardware when the receiver detects a break frame. It can be cleared by a software sequence (read UART\_STS register first, then read UART\_DAT register).

### 15.4.3.6 Framing error

A framing error occurs when a stop bit is not received and recognized at the expected time. At this time, the frame error flag UART\_STS.FEF will be set by hardware, and the invalid data will be transferred from the shift register to the UART\_DAT register. During single-byte communication, no framing error interrupt will be generated because it occurs with UART\_STS.RXDNE and the hardware will generate an interrupt when the UART\_STS.RXDNE flag is set.

## 15.4.3.7 **Overrun error**

When UART\_STS.RXDNE is still '1', when the data currently received in the shift register needs to be transferred to the RDR register, an overflow error will be detected, and the hardware will set UART\_STS.OREF. When this bit is set, the value in the RDR register is not lost, but the data in the shift register is overwritten. It is cleared by a software sequence (read UART\_STS register first, then write UART\_DAT register).

When an overflow error occurs, UART\_STS.RXDNE is '1', and an interrupt is generated.

### 15.4.3.8 Noise error

UART\_STS.NEF is set by hardware when noise is detected on a received frame. It is cleared by software sequence (read UART\_STS register first, then write UART\_DAT register). During single-byte communication, no noise interrupt generated because it occurs with UART\_STS.RXDNE and the hardware will generate an interrupt when the UART\_STS.RXDNE flag is set.

| Sample value | NE status | Received bits | Data validity |
|--------------|-----------|---------------|---------------|
| 000          | 0         | 0             | Effective     |
| 001          | 1         | 0             | be invalid    |
| 010          | 1         | 0             | be invalid    |
| 011          | 1         | 1             | be invalid    |
| 100          | 1         | 0             | be invalid    |
| 101          | 1         | 1             | be invalid    |
| 110          | 1         | 1             | be invalid    |
| 111          | 0         | 1             | Effective     |

### Table 15-2 Data sampling for noise detection



## 15.4.4 Generation of fractional baud rate

The baud rate of the UART can be configured in the UART\_BRCF register. This register defines the integer and fractional parts of the baud rate divider. The baud rate of the transmitter and receiver should be configured to the same value. Be careful not to change the value of the UART\_BRCF register during communication, because the baud rate counter will be replaced by the new value of the baud rate register.

TX / RX baud rate =  $f_{CK}$  /(16 \*UARTDIV)

where  $f_{CK}$  is the clock provided to the peripheral: PCLK is used for UART1/2, up to 48MHz. UARTDIV is an unsigned fixed-point number.

## 15.4.4.1 UARTDIV and UART\_BRCF register configuration

Example 1:

If UARTDIV = 27.75, then:

 $DIV_Decimal = 16*0.75 = 12 = 0x0C$ 

 $DIV\_Integer = 27=0x1B$ 

So UART\_BRCF = 0x1BC

Example 2:

If UARTDIV = 20.98, then:

DIV\_Decimal = 16\*0.98 = 15.68

Nearest integer: DIV\_Decimal = 16 = 0x10, out of configurable range, so a carry to integer is required

So DIV\_Integer = 20 + 1 = 21 = 0x15

 $DIV_Decimal = 0x0$ 

So UART\_BRCF = 0x150

Example 3:

If UART\_BRCF = 0x19B:

 $DIV_Integer = 0x19 = 25$ 

 $DIV\_Decimal = 0x0B = 11$ 

So UARTDIV = 25 + 11/16 = 25.6875

#### Table 15-3 Error calculation when setting baud rate

| Ba            | ud rate | f <sub>ck</sub> =48M |                           |        |  |  |  |  |  |  |  |
|---------------|---------|----------------------|---------------------------|--------|--|--|--|--|--|--|--|
| serial number | Kbps    | reality              | Set baud rate             | Error% |  |  |  |  |  |  |  |
|               | Kops    | Teanty               | The value in the register |        |  |  |  |  |  |  |  |
| 1             | 2.4     | 2.4                  | 1250                      | 0%     |  |  |  |  |  |  |  |
| 2             | 9.6     | 9.6                  | 312.5                     | 0%     |  |  |  |  |  |  |  |
| 3             | 19.2    | 19.2                 | 156.25                    | 0%     |  |  |  |  |  |  |  |

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| 4  | 57.6  | 57.623   | 52.0625 | 0.04% |
|----|-------|----------|---------|-------|
| 5  | 115.2 | 115.1    | 26.0625 | 0.08% |
| 6  | 230.4 | 230.769  | 13      | 0.16% |
| 7  | 460.8 | 461.538  | 6.5     | 0.16% |
| 8  | 921.6 | 923.076  | 3.25    | 0.16% |
| 9  | 2250  | 2285.714 | 1.3125  | 1.58% |
| 10 | 3000  | 3000     | 1       | 0%    |

Notes: The lower the clock frequency of the CPU, the lower the error for a particular baud rate.

## 15.4.5 Receiver's tolerance clock deviation

Variations due to transmitter errors (including transmitter side oscillator variations), receiver side baud rate rounding errors, receiver side oscillator variations, variations due to transmission lines (usually due to the inconsistency between the low-to-high transition timing of the transceiver and the high-to-low transition timing of the transceiver), these factors will affect the overall clock system variation. Only when the sum of the above four changes is less than the tolerance of the UART receiver, the UART asynchronous receiver can work normally.

When receiving data normally, the tolerance of the UART receiver depends on the selection of the data bit length and whether it is generated using a fractional baud rate. The tolerance of the UART receiver is equal to the maximum tolerable variation.

#### Table 15-4 When DIV\_Decimal = 0. Tolerance of UART receiver

| WL bit | NF is an error | NF is don't care |  |  |  |  |  |  |
|--------|----------------|------------------|--|--|--|--|--|--|
| 0      | 3.75%          | 4.375%           |  |  |  |  |  |  |
| 1      | 3.41%          | 3.97%            |  |  |  |  |  |  |

### Table 15-5 When DIV\_Decimal != 0. Tolerance of UART receiver

| WL bit | NF is an error | NF is don't care |  |  |  |  |  |  |
|--------|----------------|------------------|--|--|--|--|--|--|
| 0      | 3.33%          | 3.88%            |  |  |  |  |  |  |
| 1      | 3.03%          | 3.53%            |  |  |  |  |  |  |

## 15.4.6 Parity control

Parity can be enabled by configuring the UART\_CTRL1.PCEN bit.When the parity bit is enabled for transmission, A parity bit is generated, parity check is performed on reception.

#### Table 15-6 Frame format

| WL bit | PCEN bit | UART frame                                         |
|--------|----------|----------------------------------------------------|
| 0      | 0        | Start bit   8-bit data   Stop bit                  |
| 0      | 1        | Start bit   7 bits of 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     |

### **Even parity**



Configure UART\_CTRL1.PSEL to 0, and even parity can be selected.

Make the number of '1' in the transmitted data (including parity bit) be an even number. That is: if Data=1100 0101, there are 4 '1's, then the parity bit will be '0' (4 '1' in total). After the data and check digit are sent to the receiver, the receiver calculates the number of 1s in the data again. If it is an even number, the check is passed, indicating that no errors occurred during the transmission process. If it is not even, it means that an error has occurred, the UART\_STS.PEF flag is set to '1', and if UART\_CTRL1.PEIEN is enabled, an interrupt is generated.

### **Odd parity**

Configure UART\_CTRL1.PSEL to 1, you can choose odd parity.

Make the number of '1' in the transmitted data (including parity bit) be an odd number. That is: if Data=11000101, there are 4 '1's, then the parity bit will be '1' (5 '1' in total). After the data and check digit are sent to the receiver, the receiver calculates the number of 1s in the data again. If it is an odd number, the check is passed, indicating that no errors occurred during the transmission process. If it is not an odd number, it means that an error has occurred, the UART\_STS.PEF flag is set to '1', and if UART\_CTRL1.PEIEN is enabled, an interrupt is generated.

## 15.4.7 Multiprocessor communication

UART allows multiprocessor communication. The principle is: multiple processors communicate through UART, and it is necessary to determine who is the master device, and the remaining processors are all slave devices. The TX output of the master device is directly connected to the RX port of all slave device. The TX outputs of the slaves are logically AND together and connected to the RX inputs of the master.

When multi-processor communication is performed, the slave devices are all in mute mode, and the host uses a specific method to wake up a slave device to be communicated when needed, so that the slave device is in an active state and transmits data with the master device.

The UART can wake up from mute mode by idle line detection or address mark detection.

### 15.4.7.1 **Idle line detection**

The idle line detection configuration process is as follows:

- 1. Configure the UART\_CTRL1.WUM bit to 0, and the UART performs idle line detection;
- 2. When UART\_CTRL1.RCVWU is set (which can be automatically controlled by hardware or written by software under certain conditions), UART enters mute mode. In mute mode, none of the receive status bits are set, and all receive interrupts are disabled;
- 3. As shown in the Figure 15-7 below, when an idle frame is detected, UART is woken up, and then UART\_CTRL1.RCVWU is cleared by hardware. At this time, UART\_STS.IDLEF is not set.



#### Figure 15-7 Mute mode using idle line detection



### 15.4.7.2 Address mark detection

By configuring the UART\_CTRL1.WUM bit to 1, the UART performs address mark detection. The address of the receiver is programmable through the UART\_CTRL2.ADDR[3:0] bits. If the MSB is 1, the byte is considered an address, otherwise it is considered data.

In this mode, the UART can enter mute mode by:

When the receiver does not contain data, UART\_CTRL1.RCVWU can be written to 1 by software, and UART enters mute mode;

Note: When the receive buffer contains no data ( $UART\_STS.RXDNE = 0$ ), the  $UART\_CTRL1.RCVWU$  bit can be written to 0 or 1. Otherwise, the write operation is ignored.

■ When the received address does not match the address of the UART\_CTRL2.ADDR[3:0] bits, UART\_CTRL1.RCVWU is written to 1 by hardware.

In mute mode, none of the receive status bits are set and all receive interrupts are disabled.

When the received address matches the address of the UART\_CTRL2.ADDR[3:0] bits, the UART is woken up and UART\_CTRL1.RCVWU is cleared. The UART\_STS.RXDNE bit will be set when this matching address is received. Data can then be transmitted normally.



#### Figure 15-8 Mute mode detected using address mark



## 15.4.8 Single-line half-duplex communication

UART supports single-wire half-duplex communication, allowing data to be transmitted in both directions, but only allows data to be transmitted in one direction at the same time. Communication conflicts are managed by software. Through the UART\_CTRL3.HDMEN bit, you can choose whether to enable half-duplex mode.

After the half-duplex mode is turned on, the TX pin and the RX pin are interconnected inside the chip, and the RX pin is no longer used. When there is no data to transmit, TX is always released. Therefore, when not driven by the UART, the TX pin must be configured as a floating input or an open-drain output high.

## **15.5 Interrupt request**

The various interrupt events of UART are logical OR relations, if the corresponding enable control bit is set, these events can generate their own interrupts, but only one interrupt request can be generated at the same time.

| Interrupt function    | Interrupt event                      | Event flag | Enable bit |  |  |  |
|-----------------------|--------------------------------------|------------|------------|--|--|--|
|                       | Transmission data register is empty. | TXDE       | TXDEIEN    |  |  |  |
|                       | Transmission complete                | TXC        | TXCIEN     |  |  |  |
| UADT alabal interment | Receive data ready to be read        | RXDNE      | RXDNEIEN   |  |  |  |
| UART global interrupt | Data overrun error detected.         | OREF       | KADINEIEN  |  |  |  |
|                       | Idle line detected                   | IDLEF      | IDLEIEN    |  |  |  |
|                       | Parity error                         | PEF        | PEIEN      |  |  |  |

## **15.6 UART mode configuration**

#### Table 15-8 UART mode setting<sup>(1)</sup>

| Communication mode         | UART1 | UART2 |
|----------------------------|-------|-------|
| Asynchronous mode          | Y     | Y     |
| Hardware flow control mode | Ν     | Ν     |



| DMA communication mode       | Ν | Ν |
|------------------------------|---|---|
| Multiprocessor               | Y | Y |
| Smartcard mode               | Ν | Ν |
| Single-wire half duplex mode | Y | Y |
| IrDA infrared mode           | Ν | Ν |
| LIN                          | Ν | Ν |

(1) Y = support this mode, N = do not support this mode

## **15.7 UART registers**

# 15.7.1 UART register map



| Offset | Register    | 31 | 30                      | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22   | 21 | 20   | 19 | 18  | 17     | 16  | 15                   | 14            | 13                               | 12  | 11  | 10       | 6        | 8       | ٢      | 9        | 5       | 4         | 3     | 2     | 1      | 0 |
|--------|-------------|----|-------------------------|----|----|----|----|----|----|------|------|----|------|----|-----|--------|-----|----------------------|---------------|----------------------------------|-----|-----|----------|----------|---------|--------|----------|---------|-----------|-------|-------|--------|---|
| 000h   | UART_STS    |    | Reserved                |    |    |    |    |    |    |      |      |    |      |    |     | TXDE   | TXC | RXDNE                | IDLEF         | OREF                             | NEF | FEF | PEF      |          |         |        |          |         |           |       |       |        |   |
|        | Reset Value |    |                         |    |    |    |    |    |    |      |      |    |      |    |     | 1      | 1   | 0                    | 0             | 0                                | 0   | 0   | 0        |          |         |        |          |         |           |       |       |        |   |
| 004h   | UART_DAT    |    | Reserved                |    |    |    |    |    |    |      |      |    |      |    |     |        | :0] | :0]                  |               |                                  |     |     |          |          |         |        |          |         |           |       |       |        |   |
|        | Reset Value |    |                         |    |    |    |    |    |    |      |      |    |      |    |     |        |     |                      | 0             | 0                                | 0   | 0   | 0        | 0        | 0       | 0      | 0        |         |           |       |       |        |   |
| 008h   | UART_BRCF   |    | Reserved DIV_Integer[11 |    |    |    |    |    |    |      |      |    | 1:0] |    |     |        |     | DIV_Decimal<br>[3:0] |               |                                  |     |     |          |          |         |        |          |         |           |       |       |        |   |
|        | Reset Value |    |                         |    |    |    |    |    |    |      |      |    |      |    |     |        |     | 0                    | 0             | 0                                | 0   | 0   | 0        | 0        | 0       | 0      | 0        | 0       | 0         | 0     | 0     | 0      | 0 |
| 00Ch   | UART_CTRL1  |    |                         |    |    |    |    |    |    | Rese | rved |    |      |    |     |        |     | <u>.</u>             | <u>.</u>      | UEN<br>WL<br>WUM<br>PCEN<br>PSEL |     |     | PSEL     | PEIEN    | TXDEIEN | TXCIEN | RXDNEIEN | IDLEIEN | TXEN      | RXEN  | RCVWU | SDBRK  |   |
|        | Reset Value |    |                         |    |    |    |    |    |    |      |      |    |      |    |     |        |     |                      |               | 0                                | 0   | 0   | 0        | 0        | 0       | 0      | 0        | 0       | 0         | 0     | 0     | 0      | 0 |
| 010h   | UART_CTRL2  |    |                         |    |    |    |    |    |    | Rese | rved |    |      |    |     |        |     |                      | STPB<br>[1:0] |                                  |     |     | <u>.</u> | Reserved |         |        |          |         | ADDR[3:0] |       |       |        |   |
|        | Reset Value |    |                         |    |    |    |    |    |    |      |      |    | 0    | 0  |     |        |     |                      |               |                                  |     |     | 0        | 0        | 0       | 0      |          |         |           |       |       |        |   |
| 014h   | UART_CTRL3  |    |                         |    |    |    |    |    |    |      |      |    |      |    | Res | served |     |                      |               |                                  |     |     |          |          |         |        |          |         |           | HDMEN | Re    | eserve | d |
|        | Reset Value |    |                         |    |    |    |    |    |    |      |      |    |      |    |     |        |     |                      |               |                                  |     |     |          |          |         |        |          |         | 0         | 0     |       |        |   |

# 15.7.2 UART status register (UART\_STS)

Address offset: 0x00

Reset value: 0x0000 00C0



| 31 | _        |          |   |   |   |   |      |     |       | -     |      |     | -   |     | 16       |
|----|----------|----------|---|---|---|---|------|-----|-------|-------|------|-----|-----|-----|----------|
|    | Reserved |          |   |   |   |   |      |     |       |       |      |     |     |     |          |
|    | 1        | 1        | 1 | 1 | 1 | 1 |      | 1   | 1     | 1     | 1    | 1   | 1   | 1   | <u> </u> |
| 15 |          |          |   |   |   |   | 8    | 7   | 6     | 5     | 4    | 3   | 2   | 1   | 0        |
|    |          | Reserved |   |   |   |   | TXDE | TXC | RXDNE | IDLEF | OREF | NEF | FEF | PEF |          |
|    |          |          |   |   |   |   |      | r   | rc_w0 | rc_w0 | r    | r   | r   | r   | r        |

| Bit field | Name     | Describe                                                                                        |
|-----------|----------|-------------------------------------------------------------------------------------------------|
| 31:8      | Reserved | Reserved, the reset value must be maintained                                                    |
| 7         | TXDE     | The Transmit data register empty.                                                               |
|           |          | Set to 1 after power-on reset or data to be sent has been sent to the shift register. Setting   |
|           |          | UART_CTRL1.TXDEIEN will generate an interrupt.                                                  |
|           |          | This bit is cleared to 0 when the software writes the data to be sent into UART_DAT.            |
|           |          | 0: Send data buffer is not empty.                                                               |
|           |          | 1: The transmitting data buffer is empty.                                                       |
| 6         | TXC      | Transmission complete.                                                                          |
|           |          | This bit is set to 1 after power-on reset. If UART_STS.TXDE is set, this bit is set when the    |
|           |          | current data transmission is completed. Setting UART_CTRL1.TXCIEN bit will generate an          |
|           |          | interrupt.                                                                                      |
|           |          | This bit is cleared by software sequence (a read from the UART_STS register followed by a       |
|           |          | write to the UART_DAT register) or software writes 0.                                           |
|           |          | 0: Transmitting did not complete.                                                               |
|           |          | 1: Send completed.                                                                              |
| 5         | RXDNE    | The Read data register not empty.                                                               |
|           |          | This bit is set when the read data buffer receives data from the shift register. When           |
|           |          | UART_CTRL1.RXDNEIEN bit is set, an interrupt will be generated.                                 |
|           |          | Software can clear this bit by writing 0 to it or reading the UART_DAT register.                |
|           |          | 0: The read data buffer is empty.                                                               |
|           |          | 1: The read data buffer is not empty.                                                           |
| 4         | IDLEF    | IDLE line detected flag.                                                                        |
|           |          | Within one frame time, the idle state is detected at the RX pin, and this bit is set to 1. When |
|           |          | UART_CTRL1.IDLEIEN bit is set, an interrupt will be generated.                                  |
|           |          | The software can clear this bit by reading UART_STS first and then reading UART_DAT.            |
|           |          | 0: No idle frame detected.                                                                      |
|           |          | 1: idle frame detected.                                                                         |
|           |          | Note: UART_STS.IDLEF bit will not be set high again until UART_STS.RXDNE bit is set             |
|           |          | (that is, an idle line is detected again)                                                       |
| 3         | OREF     | Overrun error                                                                                   |
|           |          | With UART_STS.RXDNE set, this bit is set if the UART_DAT register receives data from            |
|           |          | the shift register. When UART_CTRL1.RXDNEIEN bit is set, an interrupt will be                   |
|           |          | generated.                                                                                      |
|           |          | The software can clear this bit by reading UART_STS first and then reading UART_DAT.            |
|           |          | 0: No overrun error was detected.                                                               |
|           |          | 1: Overflow error detected.                                                                     |



| Bit field | Name | Describe                                                                                          |
|-----------|------|---------------------------------------------------------------------------------------------------|
|           |      | Note: When this bit is set, the RDR register content will not be lost but the shift register will |
|           |      | be overwritten.                                                                                   |
| 2         | NEF  | Noise error flag.                                                                                 |
|           |      | When noise is detected in the received frame, this bit is set by hardware. It is cleared by the   |
|           |      | software sequence (read first UART_STS, read UART_DAT again).                                     |
|           |      | 0: No noise error detected.                                                                       |
|           |      | 1: Noise error detected.                                                                          |
|           |      | Note: this bit will not generate an interrupt because it appears with UART_STS.RXDNE,             |
|           |      | and the hardware will generate an interrupt when setting the UART_STS.RXDNE flag.                 |
| 1         | FEF  | Framing error.                                                                                    |
|           |      | This bit is set by hardware when synchronization dislocation, excessive noise or break            |
|           |      | character is detected. It is cleared by the software sequence (read first UART_STS, read          |
|           |      | UART_DAT again).                                                                                  |
|           |      | 0: No framing errors were detected.                                                               |
|           |      | 1: A framing error or a Break Character is detected.                                              |
|           |      | Note: this bit will not generate an interrupt because it appears with UART_STS.RXDNE,             |
|           |      | and the hardware will generate an interrupt when setting the UART_STS.RXDNE flag. If the          |
|           |      | currently transmitted data has both framing errors and overload errors, the hardware will         |
|           |      | continue to transmit the data and only set the UART_STS.OREF flag bit.                            |
| 0         | PEF  | Parity error.                                                                                     |
|           |      | This bit is set when the parity bit of the received data frame is different from the expected     |
|           |      | check value. If UART_CTRL1.PEIEN=1, it will be generate an interrupt.                             |
|           |      | The software can clear this bit by reading UART_STS first and then reading UART_DAT.              |
|           |      | Before clear UART_STS.PEF bit, software must wait for UART_STS.RXDNE =1.                          |
|           |      | 0: No parity error was detected.                                                                  |
|           |      | 1: Parity error detected.                                                                         |

# 15.7.3 UART data register (UART\_DAT)

Address offset: 0x04

Reset value: undefined (uncertain value)



 Bit field
 Name
 Description

 31:9
 Reserved
 Reserved, the reset value must be maintained

 8:0
 DATV[8:0]
 Data value

 Contains the data sent or received; Software can change the transmitted data by writing



| Bit field | Name | Description                                                                                      |
|-----------|------|--------------------------------------------------------------------------------------------------|
|           |      | these bits, or read the values of these bits to obtain the received data.                        |
|           |      | If parity is enabled, when the transmitted data is written into the register, the highest bit of |
|           |      | the data (the 7th or 8th bit depends on UART_CTRL1.WL bit) will be replaced by the parity        |
|           |      | bit.                                                                                             |

# 15.7.4 UART baud rate configuration register (UART\_BRCF)

Address offset: 0x08

Reset value: 0x0000 0000

Note: The baud counter stops counting if UART\_CTRL1.TXEN or UART\_CTRL1.RXEN are disabled respectively.



| Bit field | Name               | Describe                                     |  |  |  |
|-----------|--------------------|----------------------------------------------|--|--|--|
| 31:16     | Reserved           | Reserved, the reset value must be maintained |  |  |  |
| 15:4      | DIV_Integer [11:0] | Integer part of baud rate divider            |  |  |  |
| 3:0       | DIV_Decimal[3:0]   | Fractional part of baud rate divider         |  |  |  |

# 15.7.5 UART control register 1(UART\_CTRL1)

Address offset: 0x0C

Reset value: 0x0000 0000

| 31 |       |     |    |     |      |      |        |             |            |              |                  | 1    |      |       | 16    |
|----|-------|-----|----|-----|------|------|--------|-------------|------------|--------------|------------------|------|------|-------|-------|
|    | I     | I   | I  | I   |      |      | Rese   | erved       | I          | 1            |                  | I    | I    | I     |       |
| 15 | 14    | 13  | 12 | 11  | 10   | 9    | ۱<br>٥ | 7           | 6          | 5            | 4                | 2    | 2    | 1     |       |
|    | erved | UEN | WL | WUM | PCEN | PSEL | PEIEN  | TXDE<br>IEN | TXC<br>IEN | RXDNE<br>IEN | 4<br>IDLE<br>IEN | TXEN | RXEN | RCVWU | SDBRK |
|    |       | rw  | rw | rw  | rw   | rw   | rw     | rw          | rw         | rw           | rw               | rw   | rw   | rw    | rw    |

| Bit field | Name     | Describe                                                                                |
|-----------|----------|-----------------------------------------------------------------------------------------|
| 31:14     | Reserved | Reserved, the reset value must be maintained                                            |
| 13        | UEN      | UART enable                                                                             |
|           |          | When this bit is cleared, the divider and output of UART stop working after the current |
|           |          | byte transmission is completed to reduce power consumption. Software can set or clear   |
|           |          | this bit.                                                                               |
|           |          | 0:UART is disabled.                                                                     |
|           |          | 1:UART is enabled.                                                                      |
| 12        | WL       | Word length.                                                                            |



| Bit field | Name     | Describe                                                                             |
|-----------|----------|--------------------------------------------------------------------------------------|
|           |          | 0: 8 data bits.                                                                      |
|           |          | 1: 9 data bits.                                                                      |
|           |          | Note: If data is in transit, this bit cannot be configured.                          |
| 11        | WUM      | Wake up mode from mute mode.                                                         |
|           |          | 0: Idle frame wake-up.                                                               |
|           |          | 1: Address identifier wake-up.                                                       |
| 10        | PCEN     | Parity control enable                                                                |
|           |          | 0: Parity control is disabled.                                                       |
|           |          | 1: Parity control is enabled.                                                        |
| 9         | PSEL     | Parity selection.                                                                    |
|           |          | 0: Even parity.                                                                      |
|           |          | 1: Odd parity.                                                                       |
| 8         | PEIEN    | PE interrupt enable                                                                  |
|           |          | If this bit is set to 1, an interrupt is generated when UART_STS.PEF bit is set.     |
|           |          | 0: Parity error interrupt is disabled.                                               |
|           |          | 1: Parity error interrupt is enabled.                                                |
| 7         | TXDEIEN  | TXDE interrupt enable                                                                |
|           |          | If this bit is set to 1, an interrupt is generated when UART_STS.TXDE bit is set.    |
|           |          | 0: Send buffer empty interrupt is disabled.                                          |
|           |          | 1: Send buffer empty interrupt is enabled.                                           |
| 6         | TXCIEN   | Transmit complete interrupt enable.                                                  |
|           |          | If this bit is set to 1, an interrupt is generated when UART_STS.TXC is set.         |
|           |          | 0: Transmission completion interrupt is disabled.                                    |
|           |          | 1: Transmission completion interrupt is enabled.                                     |
| 5         | RXDNEIEN | RXDNE interrupt enable                                                               |
|           |          | If this bit is set to 1, an interrupt is generated when UART_STS.RXDNE or            |
|           |          | UART_STS.OREF is set.                                                                |
|           |          | 0: Data buffer non-empty interrupt and overrun error interrupt are disabled.         |
|           |          | 1: Data buffer non-empty interrupt and overrun error interrupt are enabled.          |
| 4         | IDLEIEN  | IDLE interrupt enable.                                                               |
|           |          | If this bit is set to 1, an interrupt is generated when UART_STS.IDLEF is set.       |
|           |          | 0: IDLE line detection interrupt is disabled.                                        |
|           |          | 1: IDLE line detection interrupt is enabled.                                         |
| 3         | TXEN     | Transmitter enable.                                                                  |
|           |          | 0: The transmitter is disabled.                                                      |
|           |          | 1:The transmitter is enabled.                                                        |
| 2         | RXEN     | Receiver enable                                                                      |
|           |          | 0: The receiver is disabled.                                                         |
|           |          | 1: The receiver is enabled.                                                          |
| 1         | RCVWU    | The receiver wakes up                                                                |
|           |          | Software can set this bit to 1 to make UART enter mute mode, and clear this bit to 0 |
|           |          | to wake up UART.                                                                     |
|           | 4        | -                                                                                    |



| Bit field | Name  | Describe                                                                                     |
|-----------|-------|----------------------------------------------------------------------------------------------|
|           |       | In idle frame wake-up mode (UART_CTRL1.WUM=0), this bit is cleared by hardware               |
|           |       | when an idle frame is detected.                                                              |
|           |       | In address wake-up mode (UART_CTRL1.WUM=1), when an address matching frame is                |
|           |       | received, this bit is cleared by hardware. Or when an address mismatch frame is received, it |
|           |       | is set to 1 by hardware.                                                                     |
|           |       | 0: The receiver is in normal operation mode.                                                 |
|           |       | 1: The receiver is in mute mode.                                                             |
| 0         | SDBRK | Send Break Character.                                                                        |
|           |       | The software transmits a break character by setting this bit to 1.                           |
|           |       | This bit is cleared by hardware during stop bit of the break frame transmission.             |
|           |       | 0: No break character was sent.                                                              |
|           |       | 1: Send a break character.                                                                   |

# 15.7.6 UART control register 2(UART\_CTRL2)

Address offset: 0x10

Reset value: 0x0000 0000

| 31   |       |      | -      |    |   |   |      |       | <br>  |   |   | -   |        | 16 |
|------|-------|------|--------|----|---|---|------|-------|-------|---|---|-----|--------|----|
|      |       |      |        |    |   |   | Rese | erved | <br>1 |   |   | 1   | 1      |    |
| 15   | 14    | 13   | 12     | 11 |   |   |      |       |       | 4 | 3 |     |        | 0  |
| Rese | erved | STPI | B[1:0] |    | 1 | 1 | Rese | erved |       |   |   | ADD | R[3:0] |    |
|      |       | r    | w      | •  | • |   | •    | •     |       |   |   | r   | w      |    |

| Bit field | Name      | Describe                                                                                 |
|-----------|-----------|------------------------------------------------------------------------------------------|
| 31:14     | Reserved  | Reserved, the reset value must be maintained                                             |
| 13:12     | STPB[1:0] | STOP bits.                                                                               |
|           |           | 00: 1 stop bit                                                                           |
|           |           | 10: 2 stop bit                                                                           |
|           |           | Other: reserved                                                                          |
| 11:4      | Reserved  | Reserved, the reset value must be maintained                                             |
| 3:0       | ADDR[3:0] | UART address.                                                                            |
|           |           | Used in the mute mode of multiprocessor communication, using address identification to   |
|           |           | wake up a UART device.                                                                   |
|           |           | In address wake-up mode (UART_CTRL1.WUM=1), if the lower four bits of the                |
|           |           | received data frame are not equal to the ADDR[3:0] value, UART will enter the mute mode; |
|           |           | If the lower four bits of the received data frame are equal to the ADDR[3:0] value, UART |
|           |           | will be awakened.                                                                        |

# 15.7.7 UART control register 3(UART\_CTRL3)

Address offset: 0x14



#### Reset value: 0x0000 0000

| 31 |   |   |   |      |       |      |       |   | <br> |       |   |          | 16 |
|----|---|---|---|------|-------|------|-------|---|------|-------|---|----------|----|
|    | 1 | 1 |   |      | 1     | Reso | erved | 1 |      |       |   |          |    |
| 15 |   |   |   |      |       |      |       |   | 4    | 3     | 2 |          | 0  |
|    | T |   |   | Rese | erved |      |       |   |      | HDMEN |   | Reserved |    |
|    | 1 |   | 1 |      |       |      | 1     |   |      | rw    |   | 11       |    |

| Bit field | Name     | Describe                                      |
|-----------|----------|-----------------------------------------------|
| 31:4      | Reserved | Reserved, the reset value must be maintained. |
| 3         | HDMEN    | Half-duplex mode enable.                      |
|           |          | This bit is used to enable half-duplex mode.  |
|           |          | 0: Half-duplex mode is disabled.              |
|           |          | 1: Half-duplex mode is enabled.               |
| 2:0       | Reserved | Reserved, the reset value must be maintained. |



# 16 Serial peripheral interface (SPI)

# **16.1 SPI introduction**

Serial peripheral interface (SPI) is able to work in master or slave mode, support full-duplex and simplex high-speed communication mode.

# 16.2 SPI main features

- Full duplex mode and simplex synchronous mode.
- Support master mode, slave mode and multi-master mode.
- Supports 8-bit or 16-bit data frame format.
- Data bit sequence programmable.
- NSS management by hardware or software.
- Clock polarity and phase programmable.



# 16.3 SPI function description

## 16.3.1 General description

Figure 16-1 SPI block diagram



To connected external devices, SPI has four pins, which are as follows:

- SCK: serial clock pin. Serial clock signal is output from the SCK pin of master device and input to SCK pin of slave device.
- MISO: master input/slave output pin. Data is received from the MISO pin of master device and send by the MISO pin of slave device.
- MOSI: master output/slave input pin. Data is send by the MOSI pin of master device and received from the MOSI pin of slave device.
- NSS: chip select pin. There are two types of NSS pin, internal pin and external pin. If the internal pin detects a high level, SPI works in the master mode. Conversely, SPI works in the slave mode. Users can use a standard I/O pin of the master device to control the NSS pin of the slave device.



### 16.3.1.1 Software NSS mode

The software slave device management is enabled when SPI\_CTRL1.SSMEN=1.

The NSS pin is not used in software NSS mode. In this mode the internal NSS signal level is driven by writing the SPI\_CTRL1.SSEL bit (master mode SPI\_CTRL1.SSEL=1, slave mode SPI\_CTRL1.SSEL=0).

#### 16.3.1.2 Hardware NSS mode

The software slave device management is disabled when SPI\_CTRL1.SSMEN=0.

**Input mode:** The NSS output of the master device is disabled (SPI\_CTRL1.MSEL=1, SPI\_CTRL2.SSOEN=0), allowing operation in multi-master mode. The master should connect NSS pin to the high level and the slave should connect NSS pin to the low level during the entire data frame transfer.

**Output mode:** NSS output of the master device is enable (SPI\_CTRL1.MSEL=1, SPI\_CTRL2.SSOEN=1). SPI as the master device must pull the NSS pin to low level, all device which connected to the master device and set to NSS hardware mode, will detect low level and enter the slave mode automatically. If the master device cannot pull the NSS pin to low level, device will enter the slave mode and generates the master mode failure error.

Note: The choice of software mode or hardware mode depends on whether NSS control is needed in the communication protocol. If not, you can choose the software mode, and release a GPIO pin for other purposes.



#### Figure 16-2 Slave selects management of hardware/software

The following figure is an example of the interconnection of single master and single slave devices





#### Figure 16-3 Master and slave applications

#### Note: NSS pin is set as input

SPI is a ring bus structure, and the master device outputs a synchronous clock signal through SCK pin, the MOSI pin of master device is connected with the MOSI pin of slave device, and the MISO pin of master device is connected with the MISO pin of slave device. Serial transfer of data between master device and slave device, through MOSI pin to send data to slave device, through MISO pin send the highest bit of the shift register of the slave device to lowest bit of the shift register of the master device, when the second bit of data is sent, the lowest bit data of the shift register will be shifted to the left by one bit and the data of the new highest bit int the shift register will be shifted to the left by one bit data of the shift register of the master device will be shifted to the left bit data of the shift register of the master device will be shifted to the left by one bit and the shift register of the master device will be shifted to the left by one bit and the shift register of the master device will be shifted to the left by one bit data of the shift register of the master device will be shifted to the left by one bit and the shift register of the master device will be shifted to the left by one bit data of the shift register of the master device will be shifted to the left by one bit and the new data that the master device has been received will be stored in the lowest bit of the shift register.

### 16.3.1.3 **SPI timing mode**

User can selects the clock edge of data capture by setting SPI\_CTRL1.CLKPOL bit and SPI\_CTRL1.CLKPHA bit.

- When CLKPOL = 0, CLKPHA = 0, the SCK pin will keep low in idle state, and the data will be sampled at the first edge, which is rising edge.
- When CLKPOL = 0, CLKPHA = 1, the SCK pin will keep low in idle state, and the data will be sampled at the second edge, which is falling edge.
- When CLKPOL = 1, CLKPHA = 0, the SCK pin will keep high in idle state, and the data will be sampled at the first edge, which is falling edge.
- When CLKPOL = 1, CLKPHA = 1, the SCK pin will keep high in idle state, and the data will be sampled at the second edge, which is rising edge.

Regardless of the timing mode used, the master and slave configuration must be the same.



Figure 16-4 is the combination timing of four CLKPHA and CLKPOL bits transmitted by SPI when the SPI\_CTRL1.LSBFF=0.



Figure 16-4 Data clock timing diagram

## 16.3.1.4 **Data format**

User can selects the data bit order by setting the SPI\_CTRL1.LSBFF bit. When SPI\_CTRL1.LSBFF = 0, SPI will send the high-order data (MSB) first; When SPI\_CTRL1.LSBFF = 1, SPI will send low-order data (LSB) first.

User can selects the data frame format by setting the SPI\_CTRL1.DATFF bit. When SPI\_CTRL1.DATFF = 0, SPI data frame length is 8-bit; When SPI\_CTRL1.DATFF = 1, SPI data frame length is 16-bit

## 16.3.2 SPI work mode

## 16.3.2.1 Master full duplex mode

Master full duplex mode (SPI\_CTRL1.MSEL=1 (master), SPI\_CTRL1.BIDIRMODE=0 (two-wire one-way),



SPI\_CTRL1.RONLY=0 (sending mode and receiving mode)). After the first data is written to the SPI\_DAT register, the transmission will start. When the first bit of the data is sent, the data bytes are loaded from the data register into the shift register in parallel, and then according to the configuration of the SPI\_CTRL1.LSBFF bit, the data bits follow the MSB or LSB order is serially shifted to the MOSI pin. At the same time, the data received on the MISO pin is serially shifted into the shift register in the same order and then loaded into the SPI\_DAT register in parallel. The software operation process is as follows:

- 1. Enable SPI module, set SPI\_CTRL1.SPIEN = 1.
- 2. Write the first data to be sent into SPI\_DAT register (this operation will clear SPI\_STS.TE bit).
- 3. Wait for SPI\_STS.TE bit to be set to '1', and write the second data to be sent into SPI\_DAT. Wait for SPI\_STS.RNE bit to be set to '1', read SPI\_DAT to get the first received data, and the SPI\_STS.RNE bit will be cleared by hardware while reading SPI\_DAT. Repeat the above operation, sending subsequent data and receiving n-1 data at the same time;
- 4. Wait for SPI\_STS.RNE bit to be set to '1' to receive the last data;
- 5. Wait for SPI\_STS.TE to be set to '1', then wait for SPI\_STS.BUSY bit to be cleared and turn off SPI module.

The process of data sending and data receiving can also be implemented in the interrupt handler generated by the rising edge of the SPI\_STS.RNE or SPI\_STS.TE flag.

#### Figure 16-5 Schematic diagram of the change of TE/RNE/BUSY when the host is continuously transmitting in full duplex mode



### 16.3.2.2 Master two-wire one-way send-only mode

Master two-wire one-way send-only mode (SPI\_CTRL1.MSEL = 1(master), SPI\_CTRL1.BIDIRMODE = 0(two-wire one-way), SPI\_CTRL1.RONLY = 0(sending mode and receiving mode)). Master two-wire one-way send-only mode is similar to master full-duplex mode. The difference is that this mode will not read the received data, so the



SPI\_STS.OVER bit will be set to '1', and the software will ignore it. The software operation process is as follows:

- 1. Enable SPI module, set SPI\_CTRL1.SPIEN = 1.
- 2. Write the first data to be sent into SPI\_DAT register (this operation will clear SPI\_STS.TE bit).
- 3. Wait for SPI\_STS.TE bit to be set to '1', and write the second data to be sent into SPI\_DAT. Repeat this operation to send subsequent data;
- 4. After writing the last data to SPI\_DAT, wait for SPI\_STS.TE bit to set '1'; then wait for SPI\_STS.BUSY bit to be cleared to complete the transmission of all data.

The process of data sending can also be implemented in the interrupt handler generated by the rising edge of the SPI\_STS.TE flag.

#### Figure 16-6 Schematic diagram of TE/BUSY change when the host transmits continuously in one-way only mode



#### 16.3.2.3 Master two-wire one-way receive-only mode

Master two-wire one-way receive-only mode (SPI\_CTRL1.MSEL = 1(master), SPI\_CTRL1.BIDIRMODE = 0(two-wire one-way), SPI\_CTRL1.RONLY = 1(receive-only mode)). When SPI\_CTRL1.SPIEN=1, the receiving process starts. The data bits from the MISO pin are sequentially shifted into the shift register and then loaded into the SPI\_DAT register(receive buffer) in parallel. The software operation process is as follows:

- 1. Enable the receive-only mode (SPI\_CTRL1.RONLY=1).
- 2. Enable SPI module, set SPI\_CTRL1.SPIEN=1:
  - In master mode, SCK clock signal is generated immediately, and serial data is continuously received before SPI is turned off(SPI\_CTRL1.SPIEN=0);
  - In slave mode, serial data is continuously received when the SPI master device pulls low the NSS signal



and generates SCK clock.

3. Wait for SPI\_STS.RNE bit to be set to '1', read the SPI\_DAT register to get the received data, and the SPI\_STS.RNE bit will be cleared by hardware while reading SPI\_DAT register. Repeat this operation to receive all data.

The process of data receiving can also be implemented in the interrupt handler generated by the rising edge of the SPI\_STS.RNE flag.

# Figure 16-7 Schematic diagram of RNE change when continuous transmission occurs in receive-only mode (BIDIRMODE=0 and RONLY=1)



### 16.3.2.4 Master one-wire bidirectional send mode

Master one-wire bidirectional send mode (SPI\_CTRL1.MSEL = 1(master), SPI\_CTRL1.BIDIRMODE = 1(one-wire bidirectional), SPI\_CTRL1.BIDIROEN = 1(send-only mode), SPI\_CTRL1.RONLY = 0(sending mode and receiving mode)). After the data is written to the SPI\_DAT register (send buffer), the transmission process starts. This mode does not receive data. At the same time as the first data bit is send, the data to be sent is loaded into the 8-bit shift register in parallel, and then according to the configuration of the SPI\_CTRL1.LSBFF bit, the SPI serially shifts the data bits to the MOSI pin in MSB or LSB order

The software operation flow of the master one-wire bidirectional send mode is the same as that of the send-only mode.

### 16.3.2.5 Master one-wire bidirectional receive mode

Master one-wire bidirectional receive mode (SPI\_CTRL1.MSEL = 1(master), SPI\_CTRL1.BIDIRMODE = 1(onewire bidirectional), SPI\_CTRL1.BIDIROEN = 0(receive-only mode), SPI\_CTRL1.RONLY = 0(sending mode and receiving mode)). When SPI\_CTRL1.SPIEN=1, the receiving process starts. There is no data output in this mode, the received data bits are sequentially and serially shifted into the shift register, and then loaded into the SPI\_DAT register (receive buffer) in parallel

The software operation flow of the master one-wire bidirectional receive mode is the same as that of the receive-only mode.

### 16.3.2.6 Slave full duplex mode

Slave full duplex mode (SPI\_CTRL1.MSEL = 0(slave), SPI\_CTRL1.BIDIRMODE = 0(two-wire one-way) and



 $SPI\_CTRL1.RONLY = 0$  (sending mode and receiving mode)). The data transfer process begins when the slave device receives the first clock edge. Before the master starts data transfer, software must ensure that the data to be send is written to the  $SPI\_DAT$  register.





## 16.3.2.7 Slave two-wire one-way send-only mode

Slave two-wire one-way send-only mode (SPI\_CTRL1.MSEL = 0(slave), SPI\_CTRL1.BIDIRMODE = 0(two-wire one-way) and SPI\_CTRL1.RONLY = 0(sending mode and receiving mode)).

Figure 16-9 Schematic diagram of TE/BUSY change during continuous transmission in slave unidirectional transmit-only





mode



## 16.3.2.8 Slave two-wire one-way receive-only mode

Slave two-wire one-way receive-only mode (SPI\_CTRL1.MSEL = 0(slave), SPI\_CTRL1.BIDIRMODE = 0(twowire one-way) and SPI\_CTRL1.RONLY = 1(receive-only mode)).The data receiving process begins when the slave device receives the clock signal and the first data bit from the MOSI pin. The received data bits are sequentially and consecutively shifted serially into the shift register and then loaded into the SPI\_DAT register (receive buffer) in parallel.

## 16.3.2.9 Slave one-wire bidirectional send mode

Slave one-wire bidirectional send mode (SPI\_CTRL1.MSEL = 0(slave), SPI\_CTRL1.BIDIRMODE = 1(one-wire bidirectional) and SPI\_CTRL1.BIDIROEN = 1(send-only mode)).When the slave device receives the first edge of the clock signal, the sending process starts. No data is received in this mode, and the software must ensure that the data to be sent has been written in the SPI\_DAT register before the SPI master device starts data transmission.

## 16.3.2.10 Slave one-wire bidirectional receive mode

Slave one-wire bidirectional receive mode (SPI\_CTRL1.MSEL = 0(slave), SPI\_CTRL1.BIDIRMODE = 1(one-wire bidirectional) and SPI\_CTRL1.BIDIROEN = 0(receive-only mode)). Data receiving begins when the slave device receives the first clock edge and a data bit from the MISO pin. There is no data output in this mode, the received data bits are sequentially and consecutively shifted serially into the shift register, and then loaded into the SPI\_DAT register (receive buffer) in parallel.

*Note: The software operation process of the slave can refer to the master.* 

## 16.3.2.11 SPI initialization process

- 1. The baud rate of serial clock is defined by the SPI\_CTRL1.BR[2:0] bits (this step is ignored if it is working in slave mode).
- 2. Select SPI\_CTRL1.CLKPOL bit and SPI\_CTRL1.CLKPHA bit to define the phase relationship between data transmission and serial clock.



- 3. Set SPI\_CTRL1.DATFF bit to define 8-bit or 16-bit data frame format.
- 4. Configure SPI\_CTRL1.LSBFF bit to define whether the sequence of sending data bits is LSB or MSB.
- 5. Configure the NSS mode.
- 6. Run mode is configured by SPI\_CTRL1.MSEL bit, SPI\_CTRL1.BIDIRMODE bit, SPI\_CTRL1.BIDIROEN bit and SPI\_CTRL1.RONLY bit.
- 7. Set the SPI\_CTRL1.SPIEN=1 to enable SPI.

### 16.3.2.12 Basic send and receive process

When SPI sends a data frame, it first loads the data frame from the data buffer into the shift register, and then starts to send the loaded data. When the data is transferred from the send buffer to the shift register, the send buffer empty flag is set (SPI\_STS.TE=1), and the next data can be loaded into the send buffer; if the SPI\_CTRL2.TEINTEN bit is set, an interrupt will be generated; writing data to the SPI\_DAT register will clear the SPI\_STS.TE bit.

At the last edge of the sampling clock, when the data is transferred from the shift register to the receive buffer, the receive buffer non-empty flag is set (SPI\_STS.RNE=1), at this time the data is ready and can be read from the SPI\_DAT register; if the receive buffer non-empty interrupt is enabled (SPI\_CTRL2.RNEINTEN=1), an interrupt will be generated; the SPI\_STS.RNE bit can be cleared by reading the SPI\_DAT register data.

In master mode, the sending process starts when data is written to the send buffer. If the next data has been written into the SPI\_DAT register before the current data frame sending is completed, the continuous sending function can be achieved.

In slave mode, the NSS pin level is low, and the sending process starts when the first edge of the clock signal comes. To avoid accidental data transfers, software must write data to the send buffer before the data sending (it is recommended to enable the SPI slave before the master sends the clock).

In some configurations, when the last data is sent, the SPI\_STS.BUSY flag can be used to wait for the end of the data sending.

### 16.3.2.13 Continuous and discontinuous transmission

When sending data in master mode, if the software is fast enough to detect each SPI\_STS.TE rising edge (or TE interrupt), and the data is written to the SPI\_DAT register immediately before the end of the ongoing transmission. At this time, the SPI clock remains continuous between the transmission of data items, and the SPI\_STS.BUSY bit will not be cleared, continuous communication can be achieved.

If the software is not fast enough, it will result in discontinuous communication; in this case, the SPI\_STS.BUSY bit is cleared between the transmission of each data items(see Figure 16-10).

In master receive-only mode (SPI\_CTRL1.RONLY=1), communication is always continuous and the SPI\_STS.BUSY flag is always high.

In slave mode, the continuity of communication is determined by the SPI master device. However, even if the communication is continuous, the SPI\_STS.BUSY flag will be low for at least one SPI clock cycle between each data item (see Figure 16-9).



#### Figure 16-10 Schematic diagram of TE/BUSY change when BIDIRMODE = 0 and RONLY = 0 are transmitted discontinuously



## 16.3.3 Status flag

The SPI\_STS register has 3 flag bits to monitor the status of the SPI:

### 16.3.3.1 Send buffer empty flag bit (TE)

When the send buffer is empty, the SPI\_STS.TE flag is set to 1, which means that new data can be written into the SPI\_DAT register. When the send buffer is not empty, the hardware will clear this flag to 0.

#### 16.3.3.2 **Receive buffer non-empty flag bit (RNE)**

When the receive buffer is not empty, the SPI\_STS.RNE flag is set to 1, so the user knows that there is data in the receive buffer. After reading the SPI\_DAT register, the hardware will clear this flag to 0.

### 16.3.3.3 **BUSY flag bit (BUSY)**

When the transmission starts, the hardware sets the SPI\_STS.BUSY flag to 1, and after the transmission ends, the hardware clears the SPI\_STS.BUSY flag to 0.

Only when the device is in the master one-wire bidirectional receive mode, the SPI\_STS.BUSY flag will be set to 0 when the communication is on going.

The SPI\_STS.BUSY flag will be cleared to 0 in the following cases:

- End of transmission (except for continuous communication in master mode);
- Turn off the SPI module (SPI\_CTRL1.SPIEN=0);
- The master mode error occurs (SPI\_STS.MODERR=1)

When the communication is discontinuous: the SPI\_STS.BUSY flag is cleared to '0' between the transmission of each data item.

When communication is continuous: in master mode, the SPI\_STS.BUSY flag remains high during the entire transfer process; In slave mode, the SPI\_STS.BUSY flag will be low for 1 SPI clock cycle between each data item transfer. So do not use the SPI\_STS.BUSY flag to handle the sending and receiving of each data item.



## 16.3.4 **Turn off the SPI**

In order to turn off the SPI module, different operation modes require different operation steps:

#### 16.3.4.1 Master or slave full duplex mode

- 1. Wait for the SPI\_STS.RNE flag to be set to 1 and the last byte to be received;
- 2. Wait for the SPI\_STS.TE flag to be set to 1;
- 3. Wait for the SPI\_STS.BUSY flag to be cleared to 0;
- 4. Turn off the SPI module (SPI\_CTRL1.SPIEN=0).

#### 16.3.4.2 **one-way send-only mode or bidirectional send mode for master or slave**

- 1. After writing the last byte to the SPI\_DAT register, wait for the SPI\_STS.TE flag to be set to 1;
- 2. Wait for the SPI\_STS.BUSY flag to be cleared to 0;
- 3. Turn off the SPI module (SPI\_CTRL1.SPIEN=0).

### 16.3.4.3 one-way receive-only mode or bidirectional receive mode for master

- 1. Wait for the penultimate SPI\_STS.RNE to be set to 1;
- 2. Before closing the SPI module (SPI\_CTRL1.SPIEN=0), wait for 1 SPI clock cycle (using software delay);
- 3. Wait for the last SPI\_STS.RNE to be set before entering shutdown mode (or turning off the SPI module clock).

#### 16.3.4.4 **one-way receive-only mode or bidirectional receive mode for slave**

- 1. The SPI module can be turned off at any time (SPI\_CTRL1.SPIEN=0), and after the current transfer is over, the SPI module will be turned off;
- 2. If you want to enter the shutdown mode, you must wait for the SPI\_STS.BUSY flag to be set to 0 before entering the shutdown mode (or turn off the SPI module clock).

## 16.3.5 Error flag

### 16.3.5.1 Master mode failure error (MODERR)

The following two conditions will cause the master mode failure error:

- NSS pin hardware management mode, the master device NSS pin is pulled low;
- NSS pin software management mode, the SPI\_CTRL1.SSEL bit is set to 0.

When a master mode failure error occurs, the SPI\_STS.MODERR bit is set to 1. An interrupt is generated if the user enables the corresponding interrupt (SPI\_CTRL2.ERRINTEN=1). The SPI\_CTRL1.SPIEN bit and SPI\_CTRL1.MSEL bit will be write protected and both are cleared by hardware. SPI is turned off and forced into slave mode

Software performs a read or write operation to the SPI\_STS register, and then writes to the SPI\_CTRL1 register to clear the SPI\_STS.MODERR bit (in multi-master mode, the master's NSS pin must be pulled high first).

Normally, the SPI\_STS.MODERR bit of the slave cannot be set to 1. However, in a multi-master configuration, the



slave's SPI\_STS.MODERR bit may be set to 1. In this case, the SPI\_STS.MODERR bit indicates that there is a multimaster collision. The interrupt routine can perform a reset or return to the default state to recover from an error state.

## 16.3.5.2 **Overflow error (OVER)**

When the SPI\_STS.RNE bit is set to 1, but there is still data sent into the receive buffer, an overflow error will occur. At this time, the overflow flag SPI\_STS.OVER bit is set to 1. An interrupt is generated if the user enables the corresponding interrupt (SPI\_CTRL2.ERRINTEN=1). All received data is lost, and the SPI\_DAT register retains only previously unread data.

Read the SPI\_DAT register and the SPI\_STS register in turn to clear the SPI\_STS.OVER bit.

# 16.3.6 SPI interrupt

| Interrupt event               | Event flag bit | Enable control bit |  |  |
|-------------------------------|----------------|--------------------|--|--|
| Send buffer empty flag        | TE             | TEINTEN            |  |  |
| Receive buffer non empty flag | RNE            | RNEINTEN           |  |  |
| Master mode failure event     | MODERR         |                    |  |  |
| Overflow error                | OVER           | ERRINTEN           |  |  |

#### Table 16-1 SPI interrupt request

# 16.4 SPI register

## 16.4.1 SPI register overview

| Offset | Register    | 31 | 30 | 2        | 29 | 28 | 27 | 26 | 25 | 24   | 23       | 22       | 21 | 20 | 19                                             | 18 | 17 | 16 | 15        | 14       | 13 | 12       | Ξ        | 10       | 6        | ~        | 7       | 9        | 5        | 4     | 3        | 5     | -        | 0       |
|--------|-------------|----|----|----------|----|----|----|----|----|------|----------|----------|----|----|------------------------------------------------|----|----|----|-----------|----------|----|----------|----------|----------|----------|----------|---------|----------|----------|-------|----------|-------|----------|---------|
| 000h   | SPI_CTRL1   |    |    | <u>·</u> |    | (1 |    |    |    | Rese | <u> </u> | <u> </u> |    |    | <u>·                                      </u> |    |    |    | BIDIRMODE | BIDIROEN |    | Keserved | DATFF    | RONLY    | SSMEN    | SSEL     | LSBFF   | SPIEN    | E        | R[2:0 | )]       | MSEL  | CLKPOL   | CLKPHA  |
|        | Reset Value |    |    |          |    |    |    |    |    |      |          |          |    |    |                                                |    |    |    | 0         | 0        |    |          | 0        | 0        | 0        | 0        | 0       | 0        | 0        | 0     | 0        | 0     | 0        | 0       |
| 004h   | SPI_CTRL2   |    |    |          |    |    |    |    |    |      |          |          |    | Re | eserved                                        |    |    |    | <u>.</u>  | <u>.</u> |    |          | <u>.</u> | <u>.</u> | <u>.</u> | <u>.</u> | TEINTEN | RNEINTEN | ERRINTEN |       | Keserved | SSOEN | Decensed | Vestive |
|        | Reset Value | 1  |    |          |    |    |    |    |    |      |          |          |    |    |                                                |    |    |    |           |          |    |          |          |          |          |          | 0       | 0        | 0        |       |          | 0     |          |         |
| 008h   | SPI_STS     |    |    |          |    |    |    |    |    |      |          |          |    | Re | eserved                                        |    |    |    |           |          |    |          |          |          |          |          | BUSY    | OVER     | MODERR   |       | Reserved |       | TE       | RNE     |
|        | Reset Value |    |    |          |    |    |    |    |    |      |          |          |    |    |                                                |    |    |    |           |          |    |          |          |          |          |          | 0       | 0        | 0        |       | R        |       | 1        | 0       |
| 000    | SPI_DAT     |    |    |          |    |    |    |    |    | D    |          |          |    |    |                                                |    |    |    |           |          |    |          |          |          |          | DAT[     | [15:0]  |          |          |       |          |       |          |         |
| 00Ch   | Reset Value |    |    |          |    |    |    |    |    | Rese | erve     | ea       |    |    |                                                |    |    |    | 0         | 0        | 0  | 0        | 0        | 0        | 0        | 0        | 0       | 0        | 0        | 0     | 0        | 0     | 0        | 0       |

#### Table 16-2 SPI register overview

# 16.4.2 SPI control register 1 (SPI\_CTRL1)

Address: 0x00

Reset value: 0x0000



| 15            | 14           | 13   | 12    | 11    | 10    | 9     | 8    | 7     | 6     | 5 |         | 3 | 2    | 1      | 0      |
|---------------|--------------|------|-------|-------|-------|-------|------|-------|-------|---|---------|---|------|--------|--------|
| BIDIR<br>MODE | BIDIR<br>OEN | Rese | erved | DATFF | RONLY | SSMEN | SSEL | LSBFF | SPIEN |   | BR[2:0] |   | MSEL | CLKPOL | CLKPHA |
| rw            | rw           |      |       | rw    | rw    | rw    | rw   | rw    | rw    |   | rw      |   | rw   | rw     | rw     |

| Bit field | Name      | Describe                                                                                           |
|-----------|-----------|----------------------------------------------------------------------------------------------------|
| 15        | BIDIRMODE | Bidirectional data mode enable                                                                     |
|           |           | 0: Select the "two-wire one-way" mode.                                                             |
|           |           | 1: Select the "one-wire bidirectional" mode.                                                       |
| 14        | BIDIROEN  | Output enable in bidirectional mode                                                                |
|           |           | 0: Output disable (receive-only mode).                                                             |
|           |           | 1: Output enabled (send-only mode).                                                                |
|           |           | In master mode, the "one-wire" data line is the MOSI pin, and in slave mode, the "one-wire"        |
|           |           | data line is the MISO pin.                                                                         |
| 13:12     | Reserved  | Reserved, the reset value must be maintained.                                                      |
| 11        | DATFF     | Data frame format                                                                                  |
|           |           | 0: 8-bit data frame format is used for sending/receiving.                                          |
|           |           | 1: 16-bit data frame format is used for sending/receiving.                                         |
|           |           | Note: This bit can only be written when SPI is disabled (SPI_CTRL1.SPIEN=0), otherwise an          |
|           |           | error will occur.                                                                                  |
| 10        | RONLY     | Only receive mode                                                                                  |
|           |           | This bit, together with the SPI_CTRL1.BIDIRMODE bit, determines the transfer direction in          |
|           |           | two-wire one-way mode. In the application scenario of multiple slave devices, this bit is only set |
|           |           | to 1 by the accessed slave device, and only the accessed slave device can output, so as to avoid   |
|           |           | data line conflicts.                                                                               |
|           |           | 0: Full duplex (sending mode and receiving mode).                                                  |
|           |           | 1: Disable output (receive-only mode).                                                             |
| 9         | SSMEN     | Software slave device management                                                                   |
|           |           | When the SPI_CTRL1.SSMEN bit is set to 1, the NSS pin level is determined by the value of          |
|           |           | the SPI_CTRL1.SSEL bit.                                                                            |
|           |           | 0: Disable software slave device management.                                                       |
|           |           | 1: Enable software slave device management.                                                        |
| 8         | SSEL      | Internal slave device selection                                                                    |
|           |           | This bit only has meaning when the SPI_CTRL1.SSMEN bit is set. It determines the NSS level,        |
|           |           | and I/O operations on the NSS pin have no effect.                                                  |
| 7         | LSBFF     | Frame format                                                                                       |
|           |           | 0: Send MSB first.                                                                                 |
|           |           | 1: Send LSB first.                                                                                 |
|           |           | Note: This bit cannot be changed during communication.                                             |
| 6         | SPIEN     | SPI enable                                                                                         |
|           |           | 0: Disable SPI device.                                                                             |
|           |           | 1: Enable the SPI device.                                                                          |
|           |           | Note: When turning off the SPI device, please follow 16.3.4 Section's procedure operation.         |
| 5:3       | BR[2:0]   | Baud rate control                                                                                  |
|           |           | 000: fPCLK/2                                                                                       |



| Bit field | Name   | Describe                                               |
|-----------|--------|--------------------------------------------------------|
|           |        | 001: fPCLK/4                                           |
|           |        | 010: fPCLK/8                                           |
|           |        | 011: fPCLK/16                                          |
|           |        | 100: fPCLK/32                                          |
|           |        | 101: fPCLK/64                                          |
|           |        | 110: fPCLK/128                                         |
|           |        | 111: fPCLK/256                                         |
|           |        | Note: This bit cannot be changed during communication. |
| 2         | MSEL   | Master device selection                                |
|           |        | 0: Configure as the slave device.                      |
|           |        | 1: Configure as the master device.                     |
|           |        | Note: This bit cannot be changed during communication. |
| 1         | CLKPOL | Clock polarity                                         |
|           |        | 0: In idle state, SCK remains low.                     |
|           |        | 1: In idle state, SCK remains high.                    |
|           |        | Note: This bit cannot be changed during communication. |
| 0         | CLKPHA | Clock phase                                            |
|           |        | 0: Data is sampled on the first clock edge.            |
|           |        | 1: Data is sampled on the second clock edge.           |
|           |        | Note: This bit cannot be changed during communication. |

# 16.4.3 SPI control register 2 (SPI\_CTRL2)

### Address: 0x04

Reset value: 0x0000

| _ | 15 |          |  |  |  |  |  | 8 | 7           | 6            | 5            | 4    | 3     | 2     | 1    | 0     |
|---|----|----------|--|--|--|--|--|---|-------------|--------------|--------------|------|-------|-------|------|-------|
|   |    | Reserved |  |  |  |  |  |   | TE<br>INTEN | RNE<br>INTEN | ERR<br>INTEN | Rese | erved | SSOEN | Rese | erved |
|   |    |          |  |  |  |  |  |   | rw          | rw           | rw           |      |       | rw    |      |       |

| Bit field | Name     | Describe                                                                                       |
|-----------|----------|------------------------------------------------------------------------------------------------|
| 15:8      | Reserved | Reserved, the reset value must be maintained.                                                  |
| 7         | TEINTEN  | Send buffer empty interrupt enable                                                             |
|           |          | 0: Disable TE interrupt.                                                                       |
|           |          | 1: Enable TE interrupt, and interrupt request is generated when SPI_STS.TE flag is set to '1'. |
| 6         | RNEINTEN | Receive buffer non-empty interrupt enable                                                      |
|           |          | 0: Disable RNE interrupt.                                                                      |
|           |          | 1: Enable RNE interrupt, and generate interrupt request when SPI_STS.RNE flag is set to '1'.   |
| 5         | ERRINTEN | Error interrupt enable                                                                         |
|           |          | When an error (SPI_STS.OVER, SPI_STS.MODERR) is generated, this bit controls whether an        |
|           |          | interrupt is generated                                                                         |
|           |          | 0: Disable error interrupt.                                                                    |
|           |          | 1: Enable error interrupt.                                                                     |



| Bit field | Name     | Describe                                                                                      |
|-----------|----------|-----------------------------------------------------------------------------------------------|
| 4:3       | Reserved | Reserved, the reset value must be maintained.                                                 |
| 2         | SSOEN    | NSS output enable                                                                             |
|           |          | 0: Disable NSS output in master mode, the device can work in multi-master mode.               |
|           |          | 1: When the device is turned on, enable NSS output in the master mode, the device cannot work |
|           |          | in the multi-master device mode.                                                              |
| 1:0       | Reserved | Reserved, the reset value must be maintained.                                                 |

# 16.4.4 SPI status register (SPI\_STS)

#### Address: 0x08

#### Reset value: 0x0002

| 15 |   |      |       |   | 8 | 7    | 6    | 5      | 4 |          | 2 | 1  | 0   |
|----|---|------|-------|---|---|------|------|--------|---|----------|---|----|-----|
|    | 1 | Rese | erved | 1 |   | BUSY | OVER | MODERR |   | Reserved |   | TE | RNE |
|    |   |      |       |   |   | r    | r    | r      |   |          |   | r  | r   |

| Bit field | Name     | Describe                                                                                        |
|-----------|----------|-------------------------------------------------------------------------------------------------|
| 15:8      | Reserved | Reserved, the reset value must be maintained.                                                   |
| 7         | BUSY     | Busy flag                                                                                       |
|           |          | 0: SPI is not busy.                                                                             |
|           |          | 1: SPI is busy communicating or the send buffer is not empty.                                   |
|           |          | This bit is set or reset by hardware.                                                           |
|           |          | Note: special attention should be paid to the use of this sign, see Section 16.3.3 and Section  |
|           |          | 16.3.4 for details                                                                              |
| 6         | OVER     | Overflow flag                                                                                   |
|           |          | 0: No overflow error.                                                                           |
|           |          | 1: An overflow error occurred.                                                                  |
|           |          | Note: This bit is set by hardware and cleared according to the sequence of software operations. |
|           |          | For more information about software sequences, refer to 16.3.5 for details.                     |
| 5         | MODERR   | Mode error                                                                                      |
|           |          | 0: No mode error.                                                                               |
|           |          | 1: A mode error occurred.                                                                       |
|           |          | Note: This bit is set by hardware and cleared according to the sequence of software operations. |
|           |          | For more information about software sequences, refer to 16.3.5 for details.                     |
| 4:2       | Reserved | Reserved, the reset value must be maintained.                                                   |
| 1         | TE       | The send buffer is empty                                                                        |
|           |          | 0: The send buffer is not empty.                                                                |
|           |          | 1: The send buffer is empty.                                                                    |
| 0         | RNE      | Receive buffer is not empty                                                                     |
|           |          | 0: The receive buffer is empty.                                                                 |
|           |          | 1: The receive buffer is not empty.                                                             |

Nanshan District, Shenzhen, 518057, P.R.China



# 16.4.5 SPI data register (SPI\_DAT)

#### Address: 0x0C

Reset value: 0x0000

| 15 |   |   |   |     |      |       |   |   |   |   | 0 |
|----|---|---|---|-----|------|-------|---|---|---|---|---|
|    | 1 | 1 | 1 | ı ı | 1    |       | 1 | 1 | 1 | 1 |   |
|    |   |   |   |     | DAT[ | 15:0] |   |   |   |   |   |
|    |   |   |   |     |      |       |   |   |   |   | . |
|    |   |   |   |     |      |       |   |   |   |   |   |
|    |   |   |   |     | r    | W     |   |   |   |   |   |

| Bit field | name      | Describe                                                                                                 |
|-----------|-----------|----------------------------------------------------------------------------------------------------------|
| 15:0      | DAT[15:0] | Data register                                                                                            |
|           |           | Data to be sent or received                                                                              |
|           |           | The data register corresponds to two buffers: one for write (send buffer); The other is for read         |
|           |           | (receive buffer). Write operation writes data to send buffer; The read operation will return the data in |
|           |           | the receive buffer.                                                                                      |
|           |           | Note on SPI mode: According to the selection of the data frame format by the SPI_CTRL1.DATFF             |
|           |           | bit, the data sending and receiving can be 8-bit or 16-bit. To ensure correct operation, the data        |
|           |           | frame format needs to be determined before enabling the SPI.                                             |
|           |           | For 8-bit data frame format: the buffer is 8-bit, and only SPI_DAT[7:0] is used when sending and         |
|           |           | receiving. When receiving, SPI_DAT[15:8] is forced to 0.                                                 |
|           |           | For 16-bit data frame format: the buffer is 16-bit, and the entire data register is used when            |
|           |           | sending and receiving, that is, SPI_DAT[15:0].                                                           |



# **17 Beeper**

# **17.1 Introduction**

The Beeper module supports complementary outputs and can generate periodic signals to drive external passive Beeper. Used to generate a prompt tone or an alarm sound.

# **17.2 Function description**

Beeper as an independent module, is mounted on the APB bus, working clock source is LSI.

- Single or dual outputs can be configured
- Support two outputs to complement each other
- Output frequency can be configured: 1kHz, 2kHz, 4kHz, 8kHz

# **17.3 Beeper registers**

These peripheral registers must be operated in word (32-bit) mode.

## 17.3.1 Beeper register overview

#### Table 17-1 Beeper register overview

| Offset | Register    | 31<br>30<br>229<br>228<br>228<br>226<br>225<br>225<br>221<br>17<br>117<br>117<br>116<br>116<br>116<br>116<br>116<br>116<br>116 | 9   | 5    | 4    | 3     | 5     | 1             | 0         |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------|-----|------|------|-------|-------|---------------|-----------|
| 000h   | BEEPER_CTRL | Reserved                                                                                                                       | BEI | PER_ | FREQ | )_SEL | [5:0] | BEEPER_INV_EN | BEEPER_EN |
|        | Reset Value |                                                                                                                                | 0   | 0    | 0    | 0     | 0     | 0             | 0         |

# 17.3.2 Beeper control register (BEEPER\_CTRL)

#### Address offset: 0x00

Reset value: 0x0000 0000



| Bit Field | Name                 | Description                                   |
|-----------|----------------------|-----------------------------------------------|
| 31:8      | Reserved             | Reserved, the reset value must be maintained. |
| 7:2       | BEEPER_FREQ_SEL[5:0] | Beeper output frequency selection:            |

#### Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



| Bit Field | Name          | Description                                                                    |
|-----------|---------------|--------------------------------------------------------------------------------|
|           |               | 000001: 8kHz                                                                   |
|           |               | 000011: 4kHz                                                                   |
|           |               | 000111: 2kHz                                                                   |
|           |               | 001111: 1kHz                                                                   |
|           |               | Others: reserved                                                               |
| 1         | BEEPER_INV_EN | Beeper complementary output enable                                             |
|           |               | 0: Only one output, the other output is off.                                   |
|           |               | 1: Two outputs are turned on and the outputs are complementary                 |
| 0         | BEEPER_EN     | Beeper enable                                                                  |
|           |               | 0: Beeper disable(Note: After BEEPER_EN=0, the Beeper output can be turned off |
|           |               | immediately by disabling the RCC_APBPCLKEN.BEEPEREN)                           |
|           |               | 1: Beeper enable                                                               |



# 18 Debug support (DBG)

# **18.1 Overview**

N32G003 uses Cortex®-M0 core, which integrates hardware debugging module. Support instruction breakpoint (stop when instruction fetches value) and data breakpoint (stop when data access). When the core is stopped, the user can view the internal state of the core and the external state of the system. After the user's query operation is completed, the core and peripherals can be restored, and the corresponding program can continue to be executed.

The hardware debugging module of the N32G003 core can be used when it is connected to the debugger (when it is not disabled).

N32G003 supports the following debugging interfaces:

Serial wire interface



#### Figure 18-1 N32G003 level and Cortex®-M0 level debugging block diagram

ARM Cortex®-M0 core hardware debugging module can provide the following debugging functions:

- SW-DP: Serial wire debugging port
- AHB-AP: AHB access port
- BPU: Break point unit



#### DWT: Data watchpoint trigger

#### Reference:

- Cortex®-M0 Technical Reference Manual (TRM)
- ARM debug interface V5 structure specification
- ARM CoreSight development tool set (r1p0 version) technical reference manual

# **18.2 SWD function**

The debugging tool can call the debugging function through the above-mentioned SWD debugging interface.

## 18.2.1 **Pin assignment**

SWD (serial debug) interface consists of two pins: SWCLK (clock pin) and SWDIO (data input and output pin).

The pin assignment of SWD debug interface is shown in the following table:

| Debug port | Pin assignment |
|------------|----------------|
| SWDIO      | PA8            |
| SWCLK      | PA9            |

#### Table 25-1 Debug port pin

# **19 Unique device serial number (UID)**

# **19.1 Introduction**

MCU series products have two built-in unique device serial numbers with different lengths, namely 96-bit UID (Unique device ID) and 128-bit UCID (Unique Customer ID). These two device serial numbers are stored in the system configuration block of the flash memory, and the information is programmed during manufacture, and any MCU microcontroller is guaranteed to be unique under any circumstances. It can be read by user applications or external devices through CPU or SWD interface and cannot be modified.

UID is 96 bits, which is usually used as serial number or password. When writing flash memory, this unique identifier is combined with software encryption and decryption algorithm to further improve the security of code in flash memory.

UCID is 128 bits and complies with the definition of the Nations Technologies chip serial number. It contains information about chip production and version.

In addition to the above two device serial numbers, there is also a 32-bit DBGMCU\_ID, which contains the chip version number, chip model, and Flash/SRAM capacity information.

# **19.2 UID register**

Start address: 0x1FFF\_F4FC, 96 bits in length.

# **19.3 UCID register**

Start address: 0x1FFF\_F4D0, 128 bits in length.

# 19.4 DBGMCU\_ID register

Start address: 0x1FFF\_F508, 32 bits in length.

For different bytes, the low byte comes first and the high byte follows; for the same byte, the high bit comes first and the low bit follows.

| Description         | Size | Remark                                         |
|---------------------|------|------------------------------------------------|
|                     | 4bit | The lower 4 bits of the chip version number.   |
| Chip version number | 4bit | The upper 4 bits of the chip version number.   |
|                     | 4bit | The upper 4 bits of the chip model.            |
|                     |      | The Chip model consists of 12 high, middle and |
| Chip model          |      | low bits                                       |
|                     | 4bit | The middle 4 bits of the chip model.           |
|                     | 4bit | The lower 4 bits of the chip model.            |
| Elash sonasity      | 4bit | Flash capacity indicator.                      |
| Flash capacity      |      | 2KB as unit, FLASH size = N * 2KB              |

#### Table 19-1 DBGMCU\_ID bit description

Nations Technologies Inc. Tel: +86-755-86309900 Email: info@nationstech.com Address: Nations Tower, #109 Baoshen Road, Hi-tech Park North. Nanshan District, Shenzhen, 518057, P.R.China



|               |      | Note: 0x8 indicates capacity16KB; 0xF indicates |
|---------------|------|-------------------------------------------------|
|               |      | capacity 29.5KB                                 |
| SDAM somesity | 4bit | SRAM capacity indicator.                        |
| SRAM capacity |      | 1KB as unit, SRAM size = N * 1KB                |
| Reserved      | 4bit | Keep it all 1.                                  |



# 20 Version history

| Date       | Version | Remark                                                                                                                                                                                                                                                                                                                        |
|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2022.10.10 | V1.0    | Initial release                                                                                                                                                                                                                                                                                                               |
| 2023.7.7   | V1.1.0  | <ol> <li>Section 5.2.5.4.2: PA9 adds UART2_RX multiplexing function</li> <li>Section 2.2.1.6: the option byte adds USER3[6] LVR reset enable bit and the corresponding FLASH_USER register read-only bit</li> <li>Table 2-5: modify SWD access rights for L1 level</li> <li>Table 19-1: modify Flash capacity note</li> </ol> |



# 21 Notice

This document is the exclusive property of Nations Technologies Inc. (Hereinafter referred to as NATIONS). This document, and the product of NATIONS described herein (Hereinafter referred to as the Product) are owned by NATIONS under the laws and treaties of the People's Republic of China and other applicable jurisdictions worldwide.

NATIONS does not grant any license under its patents, copyrights, trademarks, or other intellectual property rights. Names and brands of third party may be mentioned or referred thereto (if any) for identification purposes only.

NATIONS reserves the right to make changes, corrections, enhancements, modifications, and improvements to this document at any time without notice. Please contact NATIONS and obtain the latest version of this document before placing orders.

Although NATIONS has attempted to provide accurate and reliable information, NATIONS assumes no responsibility for the accuracy and reliability of this document.

It is the responsibility of the user of this document to properly design, program, and test the functionality and safety of any application made of this information and any resulting product. In no event shall NATIONS be liable for any direct, indirect, incidental, special, exemplary, or consequential damages arising in any way out of the use of this document or the Product.

NATIONS Products are neither intended nor warranted for usage in systems or equipment, any malfunction or failure of which may cause loss of human life, bodily injury or severe property damage. Such applications are deemed, "Insecure Usage".

Insecure usage includes, but is not limited to: equipment for surgical implementation, atomic energy control instruments, airplane or spaceship instruments, all types of safety devices, and other applications intended to support or sustain life.

All Insecure Usage shall be made at user's risk. User shall indemnify NATIONS and hold NATIONS harmless from and against all claims, costs, damages, and other liabilities, arising from or related to any customer's Insecure Usage.

Any express or implied warranty with regard to this document or the Product, including, but not limited to, the warranties of merchantability, fitness for a particular purpose and non-infringement are disclaimed to the fullest extent permitted by law.

Unless otherwise explicitly permitted by NATIONS, anyone may not use, duplicate, modify, transcribe or otherwise distribute this document for any purposes, in whole or in part.