

# CW32W031 Reference Manual

ARM® Cortex®-M0+ Low-power wireless 32-bit MCU

**Rev 1.0** 

www.whxy.com



Statement CW32W031

## **Statement**

#### Important notice

This reference manual is aimed at application developers and provides complete information on how to use the CW32W031 microcontroller memory and peripherals. This operation applies only to CW32W031 devices.

#### Disclaimer

Wuhan Xinyuan Semiconductor Co., Ltd. reserves the right to make changes, corrections, enhancements, and modifications to the product and this document at any time without notice. Buyers should obtain the latest product information on the official website.

#### Copyright statement

The copyright of this manual belongs to Wuhan Xinyuan Semiconductor Co., LTD., and we reserve the right of final interpretation and modification of this manual and statement.

#### **Technical support**

If you have any comments or suggestions in the process of using, please feel free to contact us.

Websit: www.whxy.com

Address: 5 WuDaYuan 3rd Road, Donghu High-tech Development Zone Wuhan Hubei, China

Postcode: 430070

# **Contents**

| Sta | itemer | nt        |                                                 | 1  |
|-----|--------|-----------|-------------------------------------------------|----|
| 1   | Docu   | mentati   | ion conventions                                 | 22 |
|     | 1.1    | Typogr    | aphical conventions                             | 22 |
|     | 1.2    | Registe   | er protocol                                     | 23 |
| 2   | Syste  | m and r   | nemory overview                                 | 24 |
|     | 2.1    | System    | architecture                                    | 24 |
|     | 2.2    | Memor     | y organization                                  | 26 |
|     |        | 2.2.1     | Overview                                        | 26 |
|     |        | 2.2.2     | Memory map and register boundary addresses      | 27 |
|     | 2.3    | On-chi    | p SRAM memory                                   | 28 |
|     | 2.4    | On-chi    | p FLASH memory                                  | 29 |
|     | 2.5    | One-tin   | ne programmable OTP memory                      | 30 |
|     | 2.6    | System    | n boot configuration                            | 31 |
|     | 2.7    | Precau    | tions                                           | 32 |
| 3   | Powe   | er Contro | ol (PWR) and Power Consumption                  | 33 |
|     | 3.1    |           | ew                                              |    |
|     | 3.2    | Powers    | supply supervisor                               | 34 |
|     | 3.3    |           | ing mode                                        |    |
|     |        | 3.3.1     | Entering Sleep mode or DeepSleep mode           |    |
|     |        | 3.3.2     | Exiting Sleep mode or DeepSleep mode            | 37 |
|     |        | 3.3.3     | Operating Modes and Reset Sources               | 39 |
|     | 3.4    | Low-po    | ower consumption applied                        | 40 |
|     | 3.5    | Cortex®   | ®-M0+ kernel system control register (SCB->SCR) | 41 |
| 4   | Reset  | t and clo | ock control (RCC)                               | 42 |
|     | 4.1    | System    | ı reset                                         | 42 |
|     |        | 4.1.1     | Power on reset/Brown-out reset (POR/BOR)        | 42 |
|     |        | 4.1.2     | Pin input reset (NRST)                          | 43 |
|     |        | 4.1.3     | IWDT/WWDT reset                                 | 43 |
|     |        | 4.1.4     | LVD low voltage detection reset                 | 43 |
|     |        | 4.1.5     | Kernel SYSRESETREQ reset                        | 43 |
|     |        | 4.1.6     | Kernel LOCKUP fault reset                       |    |
|     | 4.2    | Periphe   | eral reset                                      | 44 |
|     | 4.3    | Clock a   | and Control                                     | 45 |
|     |        | 4.3.1     | Overview                                        | 45 |
|     |        |           |                                                 |    |



|     | 4.3.2   | System Clock and Operating Mode                               | 47 |
|-----|---------|---------------------------------------------------------------|----|
|     | 4.3.3   | HSE clock                                                     | 48 |
|     | 4.3.4   | HSIOSC clock                                                  | 50 |
|     | 4.3.5   | LSE clock                                                     | 51 |
|     | 4.3.6   | LSI clock                                                     | 53 |
|     | 4.3.7   | RF clock                                                      | 53 |
|     | 4.3.8   | SysClk system clock                                           | 54 |
|     | 4.3.9   | On-chip peripheral clock control                              | 54 |
| 4.4 | Clock   | Start, Calibration, and Status Detection                      | 55 |
|     | 4.4.1   | Clock start                                                   | 55 |
|     | 4.4.2   | Clock calibration                                             | 56 |
|     | 4.4.3   | Clock state detection                                         | 57 |
|     |         | 4.4.3.1 Clock stability detection                             | 57 |
|     |         | 4.4.3.2 Clock start-up failure detection                      | 58 |
|     |         | 4.4.3.3 In-flight failure detection of clocks                 | 59 |
|     | 4.4.4   | Clock verification and output                                 | 60 |
| 4.5 | SysClk  | κ system clock switch                                         | 61 |
|     | 4.5.1   | Standard Clock Switching Process                              | 62 |
|     | 4.5.2   | HSI clock switching process between different frequencies     | 63 |
|     | 4.5.3   | Example of switching from other clocks to LSE                 | 63 |
|     | 4.5.4   | Example of switching from other clocks to HSE                 | 64 |
|     | 4.5.5   | Example of switching from other clocks to LSI                 | 64 |
|     | 4.5.6   | Example of switching from other clocks to HSI                 | 65 |
| 4.6 | List of | registers                                                     | 66 |
| 4.7 | Regist  | er description                                                | 67 |
|     | 4.7.1   | SYSCTRL_CR0 System Control Register 0                         | 67 |
|     | 4.7.2   | SYSCTRL_CR1 System Control Register 1                         | 68 |
|     | 4.7.3   | SYSCTRL_CR2 SYSCTRL_CR2 System Control Register 2             | 70 |
|     | 4.7.4   | SYSCTRL_HSI Internal high frequency clock control register    | 71 |
|     | 4.7.5   | SYSCTRL_LSI Internal low frequency clock control register     | 72 |
|     | 4.7.6   | SYSCTRL_HSE External high frequency crystal control register  | 73 |
|     | 4.7.7   | SYSCTRL_LSE External low frequency crystal control register   | 75 |
|     | 4.7.8   | SYSCTRL_IER System Interrupt Enable Control Register          | 76 |
|     | 4.7.9   | SYSCTRL_ISR System Interrupt Flag Register                    | 77 |
|     | 4.7.10  | SYSCTRL_ICR System Interrupt Flag Clear Register              | 78 |
|     | 4.7.11  | SYSCTRL_AHBEN AHB Peripheral Clock Enable Control Register    | 79 |
|     | 4.7.12  | SYSCTRL_APBEN1 APB Peripheral Clock Enable Control Register 1 | 80 |
|     | 4.7.13  | SYSCTRL_APBEN2 APB Peripheral Clock Enable Control Register 2 | 81 |
|     | 4.7.14  | SYSCTRL_AHBRST AHB Peripheral Reset Control Register          | 82 |



|   |      | 4.7.15         | SYSCTRL_APBRST1 APB Peripheral Reset Control Register 1                          | 83  |
|---|------|----------------|----------------------------------------------------------------------------------|-----|
|   |      | 4.7.16         | SYSCTRL_APBRST2 APB Peripheral Reset Control Register 2                          | 84  |
|   |      | 4.7.17         | SYSCTRL_RESETFLAG System Reset Flag Register                                     | 85  |
|   |      | 4.7.18         | SYSCTRL_DEBUG Debug Status Timer Control Register                                | 86  |
|   |      | 4.7.19         | SYSCTRL_GTIM1CAP General-Purpose Timer 1 Input Capture Source Config<br>Register |     |
|   |      | 4.7.20         | SYSCTRL_GTIM2CAP General-Purpose Timer 2 Input Capture Source Config<br>Register |     |
|   |      | 4.7.21         | SYSCTRL_ATIMETR Advanced Timer ETR Source Configuration                          | 88  |
|   |      | 4.7.22         | SYSCTRL_GTIMETR General Purpose Timer ETR Source Configuration Register          | 89  |
|   |      | 4.7.23         | SYSCTRL_TIMITR Timer ITR Source Configuration Register                           | 90  |
|   |      | 4.7.24         | SYSCTRL_MCO System Clock Output Control Register                                 | 91  |
| 5 | Inte | rrupt          |                                                                                  | 92  |
|   | 5.1  | Overv          | iew                                                                              | 92  |
|   | 5.2  | Main f         | eatures                                                                          | 92  |
|   | 5.3  |                | upt priority                                                                     |     |
|   | 5.4  |                | upt vector table                                                                 |     |
|   | 5.5  |                | upt related registers                                                            |     |
|   | 5.5  | 5.5.1          |                                                                                  |     |
|   |      | 5.5.2          | NVIC interrupt enable and disable enable                                         |     |
|   |      | 5.5.3          | NVIC interrupt priority                                                          |     |
|   |      | 5.5.4          | NVIC interrupt mask                                                              |     |
|   |      | 5.5.5          | Peripheral interrupt enable                                                      |     |
|   | 5.6  |                | registers                                                                        |     |
|   | 5.7  |                | er description                                                                   |     |
|   | 5.1  | •              | ·                                                                                |     |
|   |      | 5.7.1          | NVIC_ISER Interrupt Enable Setting Register                                      |     |
|   |      | 5.7.2<br>5.7.3 | NVIC_ICER Interrupt Enable Clear Register                                        |     |
|   |      | 5.7.4          | NVIC_ICPR Interrupt Pending Clear Register                                       |     |
|   |      | 5.7.5          | NVIC_IPR0 Interrupt Priority Control Register 0                                  |     |
|   |      | 5.7.6          | NVIC_IPR1 Interrupt Priority Control Register 1                                  |     |
|   |      | 5.7.7          | NVIC_IPR2 Interrupt Priority Control Register 2                                  |     |
|   |      | 5.7.8          | NVIC_IPR3 Interrupt Priority Control Register 3                                  |     |
|   |      | 5.7.9          | NVIC_IPR4 Interrupt Priority Control Register 4                                  |     |
|   |      | 5.7.10         | NVIC_IPR5 Interrupt Priority Control Register 5                                  |     |
|   |      | 5.7.11         | NVIC_IPR6 Interrupt Priority Control Register 6                                  |     |
|   |      | 5.7.12         | NVIC_IPR7 Interrupt Priority Control Register 7                                  |     |
| 6 | RAM  | Memor          |                                                                                  |     |
|   | 6.1  |                | iew                                                                              |     |
|   | J    | v              |                                                                                  | 0 1 |



|   | 6.2  | Main   | features                                  | 104 |
|---|------|--------|-------------------------------------------|-----|
|   | 6.3  | RAM N  | Memory operation                          | 105 |
|   |      | 6.3.1  | Read operation                            | 105 |
|   |      | 6.3.2  | Write operation                           | 105 |
|   | 6.4  | Parity | / check function                          | 106 |
|   | 6.5  | List o | f registers                               | 107 |
|   | 6.6  |        | ter description                           |     |
|   |      | 6.6.1  | RAM_ADDR Parity Error Address Register    |     |
|   |      | 6.6.2  | RAM_IER Interrupt Enable Control Register |     |
|   |      | 6.6.3  | RAM_ISR Interrupt Flag Register           | 108 |
|   |      | 6.6.4  | RAM_ICR Interrupt Flag Clear Register     | 109 |
| 7 | FLAS | SH Mem | nory                                      | 110 |
|   | 7.1  | Overv  | /iew                                      | 110 |
|   | 7.2  | Main   | features                                  | 110 |
|   | 7.3  | FLASI  | H Memory organization                     | 110 |
|   | 7.4  |        | H memory read wait cycle configuration    |     |
|   | 7.5  |        | H Memory operation                        |     |
|   |      | 7.5.1  | Page Erase                                |     |
|   |      | 7.5.2  | Write operation                           |     |
|   |      | 7.5.3  | Read operation                            | 115 |
|   | 7.6  | FLASI  | H Memory protection                       | 116 |
|   |      | 7.6.1  | Erase and write protection                | 116 |
|   |      | 7.6.2  | Erase and write PC page protection        | 117 |
|   |      | 7.6.3  | Read protection                           |     |
|   |      | 7.6.4  | FLASH memory programming                  |     |
|   | 7.7  | Preca  | utions                                    | 119 |
|   | 7.8  | List o | f registers                               | 121 |
|   | 7.9  |        | ter description                           |     |
|   |      | 7.9.1  | FLASH_CR1 Control register 1              |     |
|   |      | 7.9.2  | FLASH_CR2 Control register 2              |     |
|   |      | 7.9.3  | FLASH_PAGELOCK Erase lock register        | 123 |
|   |      | 7.9.4  | FLASH_IER Interrupt Enable Register       | 124 |
|   |      | 7.9.5  | FLASH_ISR Interrupt Flag Register         |     |
|   |      | 7.9.6  | FLASH_ICR Interrupt Flag Clear Register   | 125 |
| 8 | Dire | ct mem | ory access (DMA)                          | 126 |
|   | 8.1  | Overv  | /iew                                      | 126 |
|   | 8.2  | Main   | features                                  | 126 |



|   | 8.3 | Funct                             | ional block diagram                                          | 127 |  |
|---|-----|-----------------------------------|--------------------------------------------------------------|-----|--|
|   | 8.4 | DMA t                             | transfer modes                                               | 129 |  |
|   |     | 8.4.1                             | Overview of Transfer Modes                                   | 129 |  |
|   |     | 8.4.2                             | Software trigger BLOCK transfer mode                         | 131 |  |
|   |     | 8.4.3                             | Software trigger BULK transfer mode                          | 132 |  |
|   |     | 8.4.4                             | Hardware trigger BLOCK transfer mode                         | 133 |  |
|   |     | 8.4.5                             | Hardware trigger BULK transfer mode                          | 134 |  |
|   | 8.5 | Other                             | configuration of DMA                                         | 135 |  |
|   |     | 8.5.1                             | Data width                                                   | 135 |  |
|   |     | 8.5.2                             | Data block size                                              | 135 |  |
|   |     | 8.5.3                             | Number of data blocks                                        | 135 |  |
|   |     | 8.5.4                             | Channel priority                                             | 135 |  |
|   | 8.6 | DMA i                             | interrupt                                                    | 136 |  |
|   | 8.7 | List o                            | f registers                                                  | 137 |  |
|   | 8.8 |                                   | ter description                                              |     |  |
|   |     | 8.8.1                             | DMA_ISR Interrupt Flag Register                              |     |  |
|   |     | 8.8.2                             | DMA_ICR Interrupt Flag Clear Register                        | 139 |  |
|   |     | 8.8.3                             | DMA_CSRy Channel y Control and Status Register               | 140 |  |
|   |     | 8.8.4                             | DMA_TRIGy channel y trigger suorce control register          |     |  |
|   |     | 8.8.5                             | DMA_CNTy Channel y transfer number register                  | 142 |  |
|   |     | 8.8.6                             | DMA_SRCADDRy Channel y transfer source address register      | 142 |  |
|   |     | 8.8.7                             | DMA_DSTADDRy Channel y transfer destination address register | 142 |  |
| 9 | Gen | neral-purpose input/output (GPIO) |                                                              |     |  |
|   | 9.1 | Overv                             | /iew                                                         | 143 |  |
|   | 9.2 | Main                              | features                                                     | 143 |  |
|   | 9.3 | Funct                             | ion description                                              | 144 |  |
|   |     | 9.3.1                             | Functional block diagram                                     |     |  |
|   |     | 9.3.2                             | Digital output                                               | 145 |  |
|   |     | 9.3.3                             | Digital input                                                | 146 |  |
|   |     | 9.3.4                             | Analogue function                                            | 147 |  |
|   |     | 9.3.5                             | Multiplexing function                                        | 147 |  |
|   |     | 9.3.6                             | Interrupt Function                                           | 149 |  |
|   |     | 9.3.7                             | Other functions                                              | 150 |  |
|   | 9.4 | Progr                             | amming example                                               | 151 |  |
|   |     | 9.4.1                             | Digital output programming example                           | 151 |  |
|   |     | 9.4.2                             | Digital input programming example                            | 151 |  |
|   |     | 9.4.3                             | Analog functional programming example                        | 151 |  |
|   |     | 9.4.4                             | Multiplexed function programming example                     | 151 |  |



|    |       | 9.4.5   | Interrupt function programming example                                                | 152 |
|----|-------|---------|---------------------------------------------------------------------------------------|-----|
|    | 9.5   | List of | registers                                                                             | 153 |
|    | 9.6   | Regist  | er description                                                                        | 154 |
|    |       | 9.6.1   | GPIOx_DIR GPIO I/O direction register (x = A, B, C, F)                                | 154 |
|    |       | 9.6.2   | GPIOx_OPENDRAIN GPIO output mode register ( x = A, B, C, F )                          | 154 |
|    |       | 9.6.3   | GPIOx_PDR GPIO Pull-down resistor register ( x =A, B, C, F )                          | 155 |
|    |       | 9.6.4   | GPIOx_PUR GPIO Pull-up resistor register ( x =A, B, C, F )                            | 155 |
|    |       | 9.6.5   | GPIOx_AFRH GPIO Multiplexing function register high segment ( x =A, B, C, F )         | 156 |
|    |       | 9.6.6   | GPIOx_AFRL GPIO Multiplexing function register low segment ( $x$ =A, B, C, F )        | 156 |
|    |       | 9.6.7   | GPIOx_ANALOG GPIO Analog Digital Configuration Register ( x = A, B, C, F )            | 156 |
|    |       | 9.6.8   | GPIOx_RISEIE GPIO Rising edge interrupt enable register ( x =A, B, C, F )             | 157 |
|    |       | 9.6.9   | GPIOx_FALLIE GPIO Falling edge interrupt enable register ( x = A, B, C, F )           | 157 |
|    |       | 9.6.10  | GPIOx_ISR GPIO Interrupt flag register ( x =A, B, C, F )                              | 157 |
|    |       | 9.6.11  | GPIOx_ICR GPIO Interrupt flag clear register ( x =A, B, C, F )                        | 158 |
|    |       | 9.6.12  | GPIOx_FILTER GPIO Interrupt digital filter configuration register ( $x$ =A, B, C, F ) | 158 |
|    |       | 9.6.13  | GPIOx_IDR GPIO input data register ( x =A, B, C, F )                                  | 159 |
|    |       | 9.6.14  | GPIOx_ODR GPIO output data register ( x =A, B, C, F )                                 |     |
|    |       | 9.6.15  | GPIOx_BRR GPIO port bit set clear register ( x =A, B, C, F )                          | 159 |
|    |       | 9.6.16  | GPIOx_BSRR GPIO port bit-setting clear register ( x =A, B, C, F )                     | 160 |
|    |       | 9.6.17  | GPIOx_TOG GPIO Port Bit Flip Register ( x =A, B, C, F )                               | 160 |
| 10 | Cycli | c redun | dancy check (CRC)                                                                     | 161 |
|    | 10.1  | Overvi  | ew                                                                                    | 161 |
|    | 10.2  | Main f  | eatures                                                                               | 161 |
|    | 10.3  | Functi  | onal description                                                                      | 162 |
|    |       | 10.3.1  | Algorithmic modes                                                                     | 162 |
|    |       | 10.3.2  | Input data bit width                                                                  | 164 |
|    | 10.4  | Progra  | nmming examples                                                                       | 165 |
|    |       | 10.4.1  | CRC16_CCITT algorithm mode                                                            | 165 |
|    | 10.5  | List of | registers                                                                             | 166 |
|    | 10.6  |         | er descriptions                                                                       |     |
|    |       | 10.6.1  | CRC_CR control register                                                               |     |
|    |       | 10.6.2  | CRC_DR data register                                                                  |     |
|    |       | 10.6.3  | CRC_RESULT result register                                                            | 167 |
| 11 | Auto  | matic w | vake-up timer (AWT)                                                                   |     |
|    | 11.1  |         | iew                                                                                   |     |
|    | 11.2  |         | eatures                                                                               |     |
|    | 11.3  |         | onal description                                                                      |     |
|    | 11.0  | 11.3.1  | Functional block diagram                                                              |     |
|    |       | 11.5.1  | i unchonal block diagram                                                              | 109 |



|    |      | 11.3.2   | Timing function                              | 171 |
|----|------|----------|----------------------------------------------|-----|
|    |      | 11.3.3   | Count function                               | 173 |
|    | 11.4 | Low po   | ower mode                                    | 174 |
|    | 11.5 | AWT in   | nterrupts                                    | 174 |
|    | 11.6 | Debug    | ging support                                 | 174 |
|    | 11.7 | List of  | registers                                    | 175 |
|    | 11.8 |          | er descriptions                              |     |
|    |      | 11.8.1   | AWT_CR control register                      |     |
|    |      | 11.8.2   | AWT_ARR reload value register                |     |
|    |      | 11.8.3   | AWT_CNT count value register                 |     |
|    |      | 11.8.4   | AWT_IER interrupt enable register            |     |
|    |      | 11.8.5   | AWT_ISR interrupt flag register              | 177 |
|    |      | 11.8.6   | AWT_ICR interrupt flag clear register        | 178 |
| 12 | Real | time clo | ock (RTC)                                    | 179 |
|    | 12.1 | Overvi   | ew                                           | 179 |
|    | 12.2 | Main fe  | eatures                                      | 179 |
|    | 12.3 | Function | onal description                             | 180 |
|    |      | 12.3.1   | Functional block diagram                     |     |
|    |      | 12.3.2   | Functional overview                          |     |
|    |      | 12.3.3   | RTC initialization settings                  | 182 |
|    |      | 12.3.4   | Register lock function                       | 183 |
|    |      | 12.3.5   | Register access operations                   | 183 |
|    |      | 12.3.6   | RTCOUT output                                | 184 |
|    |      | 12.3.7   | 1Hz signal output                            | 184 |
|    |      | 12.3.8   | Clock error compensation                     | 185 |
|    |      | 12.3.9   | Alarm clock A and alarm clock B              | 186 |
|    |      | 12.3.10  | Period interrupt function                    | 187 |
|    |      | 12.3.11  | Automatic wake-up function                   | 188 |
|    |      | 12.3.12  | Timestamp function                           | 189 |
|    |      | 12.3.13  | RTC Interrupts                               |     |
|    | 12.4 | List of  | registers                                    | 190 |
|    | 12.5 | Registe  | er descriptions                              | 191 |
|    |      | 12.5.1   | RTC_KEY key value register                   | 191 |
|    |      | 12.5.2   | RTC_CR0 control register 0                   | 192 |
|    |      | 12.5.3   | RTC_CR1 control register 1                   | 193 |
|    |      | 12.5.4   | RTC_CR2 control register 2                   | 194 |
|    |      | 12.5.5   | RTC_COMPEN clock error compensation register | 195 |
|    |      | 12.5.6   | RTC_DATE date register                       | 196 |



|    |       | 12.5.7    | RTC_TIME time register                    | 196 |
|----|-------|-----------|-------------------------------------------|-----|
|    |       | 12.5.8    | RTC_ALARMA alarm clock A control register | 197 |
|    |       | 12.5.9    | RTC_ALARMB alarm clock B control register | 198 |
|    |       | 12.5.10   | RTC_TAMPDATE timestamp date register      | 198 |
|    |       | 12.5.11   | RTC_TAMPTIME timestamp time register      | 199 |
|    |       | 12.5.12   | RTC_AWTARR wake-up timer reload value     | 199 |
|    |       | 12.5.13   | RTC_IER interrupt enable register         | 200 |
|    |       | 12.5.14   | RTC_ISR interrupt flag register           | 201 |
|    |       | 12.5.15   | RTC_ICR interrupt flag clear register     | 202 |
| 13 | Basic | timer (   | BTIM)                                     | 203 |
|    | 13.1  | Overvie   | ew                                        | 203 |
|    | 13.2  | Main fe   | eatures                                   | 203 |
|    | 13.3  | Functio   | onal description                          | 204 |
|    |       | 13.3.1    | Functional block diagram                  | 204 |
|    |       |           | 13.3.1.1 Filter unit                      |     |
|    |       |           | 13.3.1.2 Polarity selection unit          | 205 |
|    |       |           | 13.3.1.3 Edge detection unit              | 205 |
|    |       |           | 13.3.1.4 Prescaler                        | 205 |
|    |       |           | 13.3.1.5 Counting unit                    | 206 |
|    |       |           | 13.3.1.6 Flip output unit                 | 208 |
|    |       | 13.3.2    | Operating modes                           | 210 |
|    |       |           | 13.3.2.1 Timer mode                       | 211 |
|    |       |           | 13.3.2.2 Counter mode                     | 212 |
|    |       |           | 13.3.2.3 Trigger start mode               | 213 |
|    |       |           | 13.3.2.4 Gated mode                       | 214 |
|    |       | 13.3.3    | Internal cascade ITR                      | 216 |
|    |       | 13.3.4    | External interconnection ETR              | 217 |
|    | 13.4  | Debug     | ging support                              | 218 |
|    | 13.5  | Progra    | mming examples                            | 219 |
|    |       | 13.5.1    | Timer mode programming example            | 219 |
|    |       | 13.5.2    | Counter mode programming examples         | 219 |
|    |       |           | 13.5.2.1 Count external ETR signals       | 219 |
|    |       |           | 13.5.2.2 Count internal ITR signals       | 220 |
|    |       | 13.5.3    | Trigger start mode programming example    | 220 |
|    |       | 13.5.4    | Gated mode programming example            | 221 |
|    | 13.6  | List of r | registers                                 | 222 |
|    | 13.7  |           | er descriptions                           |     |
|    |       | 13.7.1    | ·                                         |     |



|    |      | 13.7.2   | BTIMx_ACR advanced control register     | 224 |
|----|------|----------|-----------------------------------------|-----|
|    |      | 13.7.3   | BTIMx_PSC Prescaler register            | 224 |
|    |      | 13.7.4   | BTIMx_ARR reload register               | 224 |
|    |      | 13.7.5   | BTIMx_CNT count register                | 225 |
|    |      | 13.7.6   | BTIMx_IER interrupt enable register     | 225 |
|    |      | 13.7.7   | BTIMx_ISR interrupt flag register       | 225 |
|    |      | 13.7.8   | BTIMx_ICR interrupt flag clear register | 226 |
|    |      | 13.7.9   | BTIMx_DMA DMA trigger register          | 226 |
| 14 | Gene | ral-purp | pose timer (GTIM)                       | 227 |
|    | 14.1 | Overvi   | ew                                      | 227 |
|    | 14.2 | Main fe  | eatures                                 | 227 |
|    | 14.3 | Functio  | onal description                        | 228 |
|    |      | 14.3.1   | Functional block diagram                |     |
|    |      |          | 14.3.1.1 Prescaler                      |     |
|    |      |          | 14.3.1.2 Counting unit                  |     |
|    |      |          | 14.3.1.3 Input control unit             |     |
|    |      |          | 14.3.1.4 Capture compare channel        | 233 |
|    |      |          | 14.3.1.5 Output control unit            | 233 |
|    |      |          | 14.3.1.6 Flip output unit               | 234 |
|    |      | 14.3.2   | Basic operating modes                   | 235 |
|    |      |          | 14.3.2.1 Timer mode                     | 235 |
|    |      |          | 14.3.2.2 Counter mode                   | 237 |
|    |      |          | 14.3.2.3 Trigger start mode             | 238 |
|    |      |          | 14.3.2.4 Gated mode                     | 240 |
|    |      | 14.3.3   | Input capture function                  | 241 |
|    |      |          | 14.3.3.1 Input capture                  | 241 |
|    |      |          | 14.3.3.2 Input capture sources          | 242 |
|    |      | 14.3.4   | Output compare function                 | 243 |
|    |      |          | 14.3.4.1 Output compare                 | 243 |
|    |      |          | 14.3.4.2 Force output function          | 244 |
|    |      |          | 14.3.4.3 PWM output function            |     |
|    |      | 14.3.5   | Encoding counting mode                  | 246 |
|    |      | 14.3.6   | Internal cascade ITR                    |     |
|    |      | 14.3.7   | On-chip peripheral interconnect ETR     | 248 |
|    | 14.4 | Direct   | memory access (DMA)                     | 249 |
|    | 14.5 | Debug    | ging support                            | 250 |
|    | 14.6 | Progra   | mming examples                          | 251 |
|    |      | 14.6.1   | Timer mode programming example          | 251 |
|    |      | 14.6.2   | Counter mode programming examples       | 251 |
|    |      |          |                                         |     |

|    |      |         | 14.6.2.1 Count external ETR signals         | 251 |
|----|------|---------|---------------------------------------------|-----|
|    |      |         | 14.6.2.2 Count internal ITR signal          | 252 |
|    |      | 14.6.3  | Trigger start mode programming example      | 253 |
|    |      | 14.6.4  | Gated mode programming example              | 254 |
|    |      | 14.6.5  | Input capture programming example           | 254 |
|    |      | 14.6.6  | Output compare programming example          | 255 |
|    |      | 14.6.7  | PWM output programming example              | 255 |
|    |      | 14.6.8  | Encoder mode programming example            | 256 |
|    | 14.7 | List of | registers                                   | 257 |
|    | 14.8 | Registe | er descriptions                             | 258 |
|    |      | 14.8.1  | GTIMx_CR0 control register 0                | 258 |
|    |      | 14.8.2  | GTIMx_CR1 control register 1                | 260 |
|    |      | 14.8.3  | GTIMx_PSC Prescaler register                | 261 |
|    |      | 14.8.4  | GTIMx_ETR external trigger control register | 261 |
|    |      | 14.8.5  | GTIMx_CMMR compare capture control register | 262 |
|    |      | 14.8.6  | GTIMx_ARR reload register                   | 262 |
|    |      | 14.8.7  | GTIMx_CNT count register                    | 262 |
|    |      | 14.8.8  | GTIMx_CCR1 compare capture register 1       | 263 |
|    |      | 14.8.9  | GTIMx_CCR2 compare capture register 2       | 263 |
|    |      | 14.8.10 | GTIMx_CCR3 compare capture register 3       | 263 |
|    |      | 14.8.11 | GTIMx_CCR4 compare capture register 4       | 263 |
|    |      | 14.8.12 | GTIMx_IER interrupt enable register         | 264 |
|    |      | 14.8.13 | GTIMx_ISR interrupt flag register           | 265 |
|    |      | 14.8.14 | GTIMx_ICR interrupt flag clear register     | 266 |
|    |      | 14.8.15 | GTIMx_DMA DMA trigger register              |     |
| L5 | Adva | nced-co | ontrol timer (ATIM)                         | 268 |
|    | 15.1 | Overvi  | ew                                          | 268 |
|    | 15.2 | Main fe | eatures                                     | 268 |
|    | 15.3 | Functio | onal description                            | 269 |
|    |      | 15.3.1  | Functional block diagram                    |     |
|    |      |         | 15.3.1.1 Clock sources selection            |     |
|    |      |         | 15.3.1.2 Update Event (UEV)                 | 270 |
|    |      |         | 15.3.1.3 Counting modes                     | 271 |
|    |      |         | 15.3.1.4 Reload register                    | 277 |
|    |      |         | 15.3.1.5 Repetition counter                 | 278 |
|    |      |         | 15.3.1.6 Compare/capture channels           | 280 |
|    |      | 15.3.2  | Input capture mode                          | 281 |
|    |      |         | 15.3.2.1 Input capture                      | 281 |
|    |      |         | 15.3.2.2 PWM input mode                     | 282 |
|    |      |         |                                             |     |



|      |                      | 15.3.2.3 Input capture trigger source                     | 283 |  |
|------|----------------------|-----------------------------------------------------------|-----|--|
|      | 15.3.3               | Output compare function                                   | 284 |  |
|      |                      | 15.3.3.1 Output compare                                   | 284 |  |
|      |                      | 15.3.3.2 Forced output                                    | 285 |  |
|      |                      | 15.3.3.3 Single pulse mode                                | 286 |  |
|      |                      | 15.3.3.4 Independent PWM output                           | 287 |  |
|      |                      | 15.3.3.5 Complementary PWM output and dead-time insertion | 293 |  |
|      |                      | 15.3.3.6 Brake function                                   | 294 |  |
|      |                      | 15.3.3.7 Compare match interrupt                          | 295 |  |
|      | 15.3.4               | Quadrature encoding counting                              | 297 |  |
|      | 15.3.5               | Trigger ADC                                               | 299 |  |
|      | 15.3.6               | DMA function                                              | 299 |  |
|      | 15.3.7               | Slave mode                                                | 300 |  |
|      |                      | 15.3.7.1 Use internal clock (master mode)                 | 300 |  |
|      |                      | 15.3.7.2 Reset function (slave mode)                      |     |  |
|      |                      | 15.3.7.3 Trigger mode (slave mode)                        |     |  |
|      |                      | 15.3.7.4 External clock mode (slave mode)                 | 302 |  |
|      |                      | 15.3.7.5 Quadrature encoding mode (slave mode)            | 302 |  |
|      |                      | 15.3.7.6 Gated function (slave mode)                      |     |  |
|      | 15.3.8               | Internal cascade ITR                                      |     |  |
|      | 15.3.9               | On-chip peripheral interconnect ETR                       |     |  |
| 15.4 | Debug                | ging support                                              | 305 |  |
| 15.5 | Programming examples |                                                           |     |  |
|      | 15.5.1               | Input capture                                             | 306 |  |
|      | 15.5.2               | PWM input                                                 | 306 |  |
|      | 15.5.3               | Output compare function                                   | 307 |  |
|      | 15.5.4               | Complementary PWM output                                  | 307 |  |
|      | 15.5.5               | DMA function                                              | 308 |  |
|      | 15.5.6               | Trigger mode                                              | 309 |  |
|      | 15.5.7               | Gated Mode                                                | 310 |  |
|      | 15.5.8               | Internal cascade ITR                                      | 310 |  |
| 15.6 | List of              | registers                                                 | 311 |  |
| 15.7 | Registe              | er descriptions                                           | 312 |  |
|      | 15.7.1               | ATIM_CR control register                                  |     |  |
|      | 15.7.2               | ATIM_ARR reload register                                  | 314 |  |
|      | 15.7.3               | ATIM_CNT count register                                   | 315 |  |
|      | 15.7.4               | ATIM_ISR interrupt flag register                          |     |  |
|      | 15.7.5               | ATIM_ICR interrupt flag clear register                    | 317 |  |
|      | 15.7.6               | ATIM_MSCR master-slave mode control register              | 318 |  |
|      |                      |                                                           |     |  |



|    |       | 15.7.7   | ATIM_FLTR output control/input filter register    | 319 |
|----|-------|----------|---------------------------------------------------|-----|
|    |       | 15.7.8   | ATIM_TRIG trigger ADC control register            | 321 |
|    |       | 15.7.9   | ATIM_DTR dead-time register                       | 322 |
|    |       | 15.7.10  | ATIM_RCR repeat count register                    | 323 |
|    |       | 15.7.11  | ATIM_CH1CR channel 1 control register             | 323 |
|    |       | 15.7.12  | ATIM_CH2CR channel 2 control register             | 325 |
|    |       | 15.7.13  | ATIM_CH3CR channel 3 control register             | 325 |
|    |       | 15.7.14  | ATIM_CH4CR channel 4 control register             | 325 |
|    |       | 15.7.15  | ATIM_CH1CCRA channel 1 compare capture register A | 326 |
|    |       | 15.7.16  | ATIM_CH1CCRB channel 1 compare capture register B | 326 |
|    |       | 15.7.17  | ATIM_CH2CCRA channel 2 compare capture register A | 326 |
|    |       | 15.7.18  | ATIM_CH2CCRB channel 2 compare capture register B | 326 |
|    |       | 15.7.19  | ATIM_CH3CCRA channel 3 compare capture register A | 326 |
|    |       | 15.7.20  | ATIM_CH3CCRB channel 3 compare capture register B | 327 |
|    |       | 15.7.21  | ATIM_CH4CCR channel 4 compare capture register    | 327 |
| 16 | Indep | 328      |                                                   |     |
|    | 16.1  | Overvi   | ew                                                | 328 |
|    | 16.2  | Main F   | eatures                                           | 328 |
|    | 16.3  | Function | onal description                                  | 329 |
|    |       | 16.3.1   | Functional block diagram                          | 329 |
|    |       | 16.3.2   | Operating modes                                   | 329 |
|    |       | 16.3.3   | Window options                                    | 330 |
|    |       | 16.3.4   | Register lock function                            | 330 |
|    |       | 16.3.5   | Start refresh and stop                            | 330 |
|    |       | 16.3.6   | Status register                                   | 331 |
|    |       | 16.3.7   | Timing duration setting                           | 332 |
|    | 16.4  | Progra   | mming examples                                    | 333 |
|    |       | 16.4.1   | Configure IWDT as independent watchdog            | 333 |
|    |       | 16.4.2   | Configure IWDT as window watchdog                 | 333 |
|    |       | 16.4.3   | Refresh IWDT (feed dog operation)                 | 333 |
|    | 16.5  | List of  | registers                                         | 334 |
|    | 16.6  | Registe  | er descriptions                                   | 335 |
|    |       | 16.6.1   | IWDT_KR key-value register                        | 335 |
|    |       | 16.6.2   | IWDT_CR control register                          |     |
|    |       | 16.6.3   | IWDT_ARR reload register                          |     |
|    |       | 16.6.4   | IWDT_CNT count value register                     |     |
|    |       | 16.6.5   | IWDT_WINR window register                         |     |
|    |       | 16.6.6   | IWDT SR status register                           | 338 |



| 17 | Window watchdog timer (WWDT) |          |                                             | 339 |
|----|------------------------------|----------|---------------------------------------------|-----|
|    | 17.1                         | Overvi   | iew                                         | 339 |
|    | 17.2                         | Main fe  | eatures                                     | 339 |
|    | 17.3                         | Functi   | onal description                            | 340 |
|    |                              | 17.3.1   | Functional block diagram                    |     |
|    |                              | 17.3.2   | Operating mode                              |     |
|    |                              | 17.3.3   | Refresh counter                             | 341 |
|    |                              | 17.3.4   | Dog-feeding time                            | 341 |
|    |                              | 17.3.5   | Reset and interrupt                         | 342 |
|    | 17.4                         | Progra   | amming examples                             | 343 |
|    | 17.5                         | List of  | registers                                   | 344 |
|    | 17.6                         | Registe  | er descriptions                             | 345 |
|    |                              | 17.6.1   | WWDT_CR0 control register 0                 | 345 |
|    |                              | 17.6.2   | WWDT_CR1 control register 1                 | 345 |
|    |                              | 17.6.3   | WWDT_SR status register                     | 346 |
| 18 | Univ                         | ersal As | synchronous Receiver/Transmitter (UART)     | 347 |
|    | 18.1                         | Overvi   | iew                                         | 347 |
|    | 18.2                         | Main fe  | eatures                                     | 347 |
|    | 18.3                         | Functi   | onal description                            | 348 |
|    |                              | 18.3.1   | Functional block diagram                    |     |
|    |                              | 18.3.2   | Synchronous mode                            |     |
|    |                              |          | 18.3.2.1 Baud rate setting                  | 350 |
|    |                              |          | 18.3.2.2 Data transmission and reception    | 351 |
|    |                              | 18.3.3   | Asynchronous mode                           | 352 |
|    |                              |          | 18.3.3.1 Data frame format                  | 352 |
|    |                              |          | 18.3.3.2 Fractional baud rate generator     | 353 |
|    |                              |          | 18.3.3.3 Transmit control                   | 357 |
|    |                              |          | 18.3.3.4 Receive control                    | 358 |
|    |                              |          | 18.3.3.5 Single-wire half-duplex mode       | 359 |
|    |                              |          | 18.3.3.6 Multi-machine communicatio         | 359 |
|    |                              |          | 18.3.3.7 Hardware flow control              | 361 |
|    |                              | 18.3.4   | LIN Mode                                    | 363 |
|    |                              |          | 18.3.4.1 LIN send                           |     |
|    |                              |          | 18.3.4.2 LIN receive                        |     |
|    |                              | 18.3.5   | Timer operating mode                        |     |
|    |                              |          | 18.3.5.1 Waiting for timeout detection mode |     |
|    |                              |          | 18.3.5.2 Receive idle detection mode        |     |
|    |                              |          | 18.3.5.3 Auto baud rate detection mode      | 366 |



|    |       |          | 18.3.5.4 General purpose timer mode                | 366 |
|----|-------|----------|----------------------------------------------------|-----|
|    | 18.4  | Low po   | ower mode                                          | 367 |
|    | 18.5  | UART i   | nterrupts                                          | 368 |
|    | 18.6  | Direct I | Memory Access (DMA)                                | 370 |
|    | 18.7  | Progra   | mming examples                                     | 371 |
|    |       | 18.7.1   | Asynchronous full-duplex programming examples      | 371 |
|    |       |          | 18.7.1.1 Transmit data in query mode               |     |
|    |       |          | 18.7.1.2 Receive data in query mode                | 372 |
|    |       |          | 18.7.1.3 Transmit data in interrupt mode           | 373 |
|    |       |          | 18.7.1.4 Receive data in interrupt mode            | 374 |
|    |       |          | 18.7.1.5 DMA transmits data                        | 375 |
|    |       |          | 18.7.1.6 DMA receives data                         | 376 |
|    |       | 18.7.2   | Synchronous half-duplex programming examples       | 377 |
|    |       |          | 18.7.2.1 Transmit data in query mode               | 377 |
|    |       |          | 18.7.2.2 Receive data in query mode                | 377 |
|    |       | 18.7.3   | Single-wire half-duplex programming examples       | 378 |
|    |       |          | 18.7.3.1 Transmit data in query mode               | 378 |
|    |       |          | 18.7.3.2 Receive data in query mode                | 379 |
|    | 18.8  | List of  | registers                                          | 380 |
|    | 18.9  | Registe  | er descriptions                                    | 381 |
|    |       | 18.9.1   | UARTx_CR1 control register 1                       | 381 |
|    |       | 18.9.2   | UARTx_CR2 control register 2                       | 383 |
|    |       | 18.9.3   | UARTx_BRRI baud rate counter integer part register | 384 |
|    |       | 18.9.4   | UARTx_BRRF baud rate counter fractional register   | 384 |
|    |       | 18.9.5   | UARTx_TIMARR Timer reload register                 | 384 |
|    |       | 18.9.6   | UARTx_TIMCNT Timer count register                  | 385 |
|    |       | 18.9.7   | UARTx_TDR transmit data register                   | 385 |
|    |       | 18.9.8   | UARTx_RDR receive data register                    | 385 |
|    |       | 18.9.9   | UARTx_IER interrupt enable register                | 386 |
|    |       | 18.9.10  | UARTx_ISR interrupt flag register                  | 387 |
|    |       | 18.9.11  | UARTx_ICR interrupt flag clear register            | 388 |
|    |       | 18.9.12  | UARTx_ADDR slave address register                  | 389 |
|    |       | 18.9.13  | UARTx_MASK slave address mask register             | 389 |
| 19 | Seria | l periph | neral interface (SPI)                              | 390 |
|    | 19.1  | Overview |                                                    | 390 |
|    | 19.2  | Main fe  | eatures                                            | 390 |
|    | 19.3  |          | onal description                                   |     |
|    |       | 19.3.1   | Functional block diagram                           |     |
|    |       |          | <u> </u>                                           |     |



|    |        | 19.3.2        | Communication timing and data format                       | 393 |
|----|--------|---------------|------------------------------------------------------------|-----|
|    |        | 19.3.3        | Slave select pin CS                                        | 395 |
|    |        | 19.3.4        | Full-duplex mode                                           | 396 |
|    |        | 19.3.5        | Single-wire half-duplex mode                               | 398 |
|    |        | 19.3.6        | Simplex mode                                               | 400 |
|    |        |               | 19.3.6.1 Master single transmitting/slave single receiving | 401 |
|    |        |               | 19.3.6.2 Master single receiving/slave single transmitting | 402 |
|    |        | 19.3.7        | Multi-machine communication                                | 403 |
|    |        | 19.3.8        | Status flags                                               | 405 |
|    |        | 19.3.9        | Error flags                                                | 406 |
|    | 19.4   | SPI int       | terrupts                                                   | 407 |
|    | 19.5   | Direct        | memory access (DMA)                                        | 408 |
|    | 19.6   |               | amming examples                                            |     |
|    |        | 19.6.1        | Full duplex/master mode                                    | 409 |
|    |        |               | 19.6.1.1 Transmit and receive in query mode                | 409 |
|    |        |               | 19.6.1.2 Transmit and receive in interrupt mode            | 410 |
|    |        |               | 19.6.1.3 Transmit and receive in DMA mode                  | 411 |
|    |        | 19.6.2        | Single-wire half-duplex/master mode                        | 413 |
|    |        |               | 19.6.2.1 Transmit in query mode                            | 413 |
|    |        |               | 19.6.2.2 Receive in query mode                             | 414 |
|    |        | 19.6.3        | Simplex mode/master mode                                   | 415 |
|    |        |               | 19.6.3.1 Transmit in query mode                            | 415 |
|    |        |               | 19.6.3.2 Receive in query mode                             | 416 |
|    | 19.7   | List of       | registers                                                  | 417 |
|    | 19.8   | Regist        | er descriptions                                            | 418 |
|    |        | 19.8.1        | SPI_CR1 control register 1                                 | 418 |
|    |        | 19.8.2        | SPI_CR2 control register 2                                 | 420 |
|    |        | 19.8.3        | SPI_SSI slave select register                              | 420 |
|    |        | 19.8.4        | SPI_IER interrupt enable register                          | 421 |
|    |        | 19.8.5        | SPI_ISR interrupt flag register                            | 422 |
|    |        | 19.8.6        | SPI_ICR interrupt flag clear register                      | 423 |
|    |        | 19.8.7        | SPI_DR data register                                       | 423 |
| 20 | I2C ir | nterface      | e                                                          | 424 |
|    | 20.1   | Overvi        | iew                                                        | 424 |
|    | 20.2   | Main features |                                                            | 424 |
|    | 20.3   |               | col description                                            |     |
|    |        | 20.3.1        | Protocol frame format                                      |     |
|    |        | 20.3.2        | Transmission response                                      | 427 |



|    |       | 20.3.3                 | Conflict detection and arbitration               | 427 |
|----|-------|------------------------|--------------------------------------------------|-----|
|    | 20.4  | Functional description |                                                  | 429 |
|    |       | 20.4.1                 | Functional block diagram                         | 429 |
|    |       | 20.4.2                 | Serial clock generator                           | 430 |
|    |       | 20.4.3                 | Input filter                                     | 431 |
|    |       | 20.4.4                 | Address comparator                               | 431 |
|    |       | 20.4.5                 | Arbitration and synchronization logic            | 432 |
|    |       |                        | 20.4.5.1 SCL synchronization                     | 432 |
|    |       |                        | 20.4.5.2 SDA arbitration                         | 432 |
|    |       | 20.4.6                 | Response control                                 | 433 |
|    |       | 20.4.7                 | I2C interrupts                                   | 433 |
|    |       | 20.4.8                 | Operating modes                                  | 434 |
|    |       |                        | 20.4.8.1 Master transmit mode                    | 434 |
|    |       |                        | 20.4.8.2 Master receive mode                     | 437 |
|    |       |                        | 20.4.8.3 Slave receive mode                      | 439 |
|    |       |                        | 20.4.8.4 Slave transmit mode                     | 441 |
|    |       |                        | 20.4.8.5 Broadcast receive mode                  | 443 |
|    |       | 20.4.9                 | Multi-master communication                       | 445 |
|    |       | 20.4.10                | I2C status codes                                 | 445 |
|    | 20.5  | Progra                 | ımming examples                                  | 450 |
|    |       | 20.5.1                 | Master transmits example                         | 450 |
|    |       | 20.5.2                 | Master receives example                          | 451 |
|    |       | 20.5.3                 | Slave receives example                           | 452 |
|    |       | 20.5.4                 | Slave transmits example                          | 452 |
|    | 20.6  | List of                | registers                                        | 453 |
|    | 20.7  | Registe                | er descriptions                                  | 454 |
|    |       | 20.7.1                 | I2C_BRREN baud rate counter enable register      | 454 |
|    |       | 20.7.2                 | I2C_BRR baud rate counter configuration register | 454 |
|    |       | 20.7.3                 | I2C_CR control register                          | 455 |
|    |       | 20.7.4                 | I2C_DR data register                             | 457 |
|    |       | 20.7.5                 | I2C_STAT status register                         | 457 |
|    |       | 20.7.6                 | I2C_ADDR0 slave address 0 register               | 457 |
|    |       | 20.7.7                 | I2C_ADDR1 slave address 1 register               | 458 |
|    |       | 20.7.8                 | I2C_ADDR2 slave address 2 register               | 458 |
|    |       | 20.7.9                 | I2C_MATCH slave address match register           | 459 |
| 21 | Infra | red mod                | dulation transmitter (IR)                        | 460 |
|    | 21.1  | Overvi                 | ew                                               | 460 |
|    | 21.2  | Main fe                | eatures                                          | 460 |



|    | 21.3  | Function | onal description                                              | 461    |
|----|-------|----------|---------------------------------------------------------------|--------|
|    |       | 21.3.1   | Infrared modulation mode                                      | 462    |
|    |       | 21.3.2   | Infrared modulation initialization configuration              | 464    |
|    |       | 21.3.3   | Infrared reception                                            | 464    |
|    | 21.4  | SYSCTI   | RL_IRMOD infrared modulation control register                 | 465    |
| 22 | Analo | g-to-di  | gital converter (ADC)                                         | 466    |
|    | 22.1  | Overvi   | ew                                                            | 466    |
|    | 22.2  | Main fe  | eatures                                                       | 466    |
|    | 22.3  | Function | onal block diagram                                            | 467    |
|    | 22.4  | Conve    | rsion timing, conversion speed, conversion accuracy, and conv | ersion |
|    |       | 22.4.1   | Conversion timing                                             |        |
|    |       | 22.4.2   | Conversion speed                                              |        |
|    |       | 22.4.3   | Conversion accuracy                                           | 470    |
|    |       | 22.4.4   | Conversion results                                            | 470    |
|    | 22.5  | Operat   | ing modes                                                     | 471    |
|    |       | 22.5.1   | Single channel single conversion mode (MODE=0)                | 472    |
|    |       | 22.5.2   | Single channel multiple conversion mode (MODE=1)              | 475    |
|    |       | 22.5.3   | Single channel continuous conversion mode (MODE=2)            | 477    |
|    |       | 22.5.4   | Sequence continuous conversion mode (MODE=3)                  | 478    |
|    |       | 22.5.5   | Sequence scan conversion mode (MODE=4)                        | 481    |
|    |       | 22.5.6   | Sequence multiple conversion mode (MODE=5)                    | 483    |
|    |       | 22.5.7   | Sequence intermittent conversion mode (MODE=6)                | 485    |
|    | 22.6  | Accum    | ulation conversion function                                   | 487    |
|    | 22.7  | Auto-o   | ff mode                                                       | 489    |
|    | 22.8  | Externa  | al trigger source                                             | 490    |
|    | 22.9  | Analog   | g watchdog                                                    | 491    |
|    |       |          | rature sensor                                                 |        |
|    |       |          | terrupts                                                      |        |
|    |       |          | registers                                                     |        |
|    |       |          | er descriptions                                               |        |
|    |       | 22.13.1  | ADC_CR0 control register 0                                    |        |
|    |       | 22.13.2  | ADC_CR1 control register 1                                    |        |
|    |       | 22.13.3  | ADC_CR2 control register 2                                    |        |
|    |       | 22.13.4  | ADC_SQR0 sequence configuration register 0                    |        |
|    |       | 22.13.5  | ADC_SQR1 sequence configuration register 1                    |        |
|    |       | 22.13.6  | ADC_VTH high threshold register                               |        |
|    |       | 22.13.7  | ADC_VTL low threshold register                                | 500    |
|    |       |          |                                                               |        |



|    |       | 22.13.8   | ADC_TRIGGER external trigger register                      | 501 |
|----|-------|-----------|------------------------------------------------------------|-----|
|    |       | 22.13.9   | ADC_START start register                                   | 503 |
|    |       | 22.13.10  | ADC_IER interrupt enable register                          | 503 |
|    |       | 22.13.11  | ADC_ISR interrupt flag register                            | 504 |
|    |       | 22.13.12  | ADC_ICR interrupt flag clear register                      | 505 |
|    |       | 22.13.13  | ADC_RESULT0 conversion result 0 register                   | 505 |
|    |       | 22.13.14  | ADC_RESULT1 conversion result 1 register                   | 506 |
|    |       | 22.13.15  | ADC_RESULT2 conversion result 2 register                   | 506 |
|    |       | 22.13.16  | ADC_RESULT3 conversion result 3 register                   | 506 |
|    |       | 22.13.17  | ADC_RESULT4 conversion result 4 register                   | 506 |
|    |       | 22.13.18  | ADC_RESULT5 conversion result 5 register                   | 506 |
|    |       | 22.13.19  | ADC_RESULT6 conversion result 6 register                   | 507 |
|    |       | 22.13.20  | ADC_RESULT7 conversion result 7 register                   | 507 |
|    |       |           | ADC_RESULTACC conversion result accumulated value register |     |
| 23 | Analo | og voltag | ge comparator (VC)                                         | 508 |
|    | 23.1  | Overvie   | ew                                                         | 508 |
|    | 23.2  | Main fe   | atures                                                     | 508 |
|    | 23.3  | Functio   | onal description                                           | 509 |
|    |       | 23.3.1    | Functional block diagram                                   |     |
|    |       | 23.3.2    | I/O pins                                                   | 511 |
|    |       | 23.3.3    | Latency/Response Time                                      | 511 |
|    |       | 23.3.4    | Polarity selection                                         | 512 |
|    |       | 23.3.5    | Digital filter                                             | 512 |
|    |       | 23.3.6    | Hysteresis function                                        | 513 |
|    |       | 23.3.7    | Window compare function                                    | 513 |
|    |       | 23.3.8    | BLANK window function                                      | 514 |
|    | 23.4  | VC inte   | rrupts                                                     | 515 |
|    | 23.5  | Prograi   | mming examples                                             | 515 |
|    | 23.6  | List of r | egisters                                                   | 516 |
|    | 23.7  | Registe   | r descriptions                                             | 517 |
|    |       | 23.7.1    | VCx_DIV resistor divider control register                  |     |
|    |       | 23.7.2    | VCx_CR0 control register 0                                 |     |
|    |       | 23.7.3    | VCx_CR1 control register 1                                 |     |
|    |       | 23.7.4    | VCx_SR status register                                     |     |
| 24 | Low   | voltage ( | detector (LVD)                                             |     |
|    | 24.1  |           | 2W                                                         |     |
|    | 24.2  |           | atures                                                     |     |
|    | 24.3  |           | onal description                                           |     |



|    |       | 24.3.1   | Functional block diagram                     | 523 |
|----|-------|----------|----------------------------------------------|-----|
|    |       | 24.3.2   | Hysteresis function                          | 524 |
|    |       | 24.3.3   | Digital filter                               | 525 |
|    | 24.4  | LVD int  | terrupts                                     | 526 |
|    | 24.5  | Progra   | nmming examples                              | 527 |
|    |       | 24.5.1   | Brown-out reset programming example          | 527 |
|    |       | 24.5.2   | Interrupt programming example                | 527 |
|    | 24.6  | List of  | registers                                    | 528 |
|    | 24.7  | Registe  | er descriptions                              | 529 |
|    |       | 24.7.1   | LVD_CR0 control register 0                   |     |
|    |       | 24.7.2   | LVD_CR1 control register 1                   |     |
|    |       | 24.7.3   | LVD_SR status register                       |     |
| 25 | Radio | o Freque | ency Systems(ChirpIoT)                       | 532 |
|    | 25.1  | Overvi   | iew                                          | 532 |
|    | 25.2  | Main fe  | eatures                                      | 532 |
|    | 25.3  |          | onal description                             |     |
|    |       | 25.3.1   | Functional block diagram                     |     |
|    |       | 25.3.2   | MAC Design                                   |     |
|    |       | 25.3.3   | Operating modes                              |     |
|    |       | 25.3.4   | Channel Active Detection(CAD)                |     |
|    |       | 25.3.5   | Intelligent SF identification                | 541 |
|    |       | 25.3.6   | DATA FIFO                                    | 541 |
|    |       | 25.3.7   | RF GPIO                                      | 542 |
|    |       | 25.3.8   | RF Communication Timing                      | 543 |
|    | 25.4  | RF inte  | errupts                                      | 544 |
|    | 25.5  |          | er descriptions                              |     |
|    |       | 25.5.1   | System control register                      | 545 |
|    |       | 25.5.2   | 3V Logic area register                       | 546 |
|    |       | 25.5.3   | DCDC register                                | 547 |
|    |       |          | 25.5.3.1 Page3                               | 547 |
|    |       | 25.5.4   | Low power consumption power control register | 547 |
|    |       |          | 25.5.4.1 Page1                               | 547 |
|    |       | 25.5.5   | Modem module register                        | 548 |
|    |       |          | 25.5.5.1 Page1                               | 548 |
|    |       |          | 25.5.5.2 Page2                               | 550 |
|    |       |          | 25.5.5.3 Page3                               | 551 |
|    |       | 25.5.6   | MAC module register                          | 552 |
|    |       |          | 25.5.6.1 Page0                               | 552 |



|    |        |                 | 25.5.6.2 Page3                                  | 553 |  |
|----|--------|-----------------|-------------------------------------------------|-----|--|
|    |        | 25.5.7          | Intelligent SF identification register          | 554 |  |
|    |        |                 | 25.5.7.1 Page1                                  | 554 |  |
|    |        |                 | 25.5.7.2 Page3                                  | 556 |  |
|    |        | 25.5.8          | PLL module register                             | 557 |  |
|    |        |                 | 25.5.8.1 Page3                                  |     |  |
|    |        | 25.5.9          | GPIO configuration register                     |     |  |
|    |        |                 | 25.5.9.1 Page0                                  |     |  |
| 26 | Debu   | _               | face (DBG)                                      |     |  |
|    | 26.1   | Overvi          | ew                                              | 560 |  |
|    | 26.2   | Serial          | wire debug port SWD                             | 560 |  |
|    | 26.3   | Debug           | communication protocol                          | 562 |  |
|    |        | 26.3.1          | Transmission protocol format                    | 562 |  |
|    |        | 26.3.2          | SW-DP state machine                             | 563 |  |
|    |        | 26.3.3          | Read and write access for SW-DP and SW-AP       | 564 |  |
|    |        | 26.3.4          | SW-DP register                                  | 565 |  |
|    |        | 26.3.5          | SW-AP register                                  | 566 |  |
|    | 26.4   | Kernel          | debugging                                       | 567 |  |
|    | 26.5   | Breakp          | point unit BPU                                  | 567 |  |
|    | 26.6   | Data o          | bservation points and tracking DWT              | 567 |  |
|    | 26.7   | Debug           | components DBG                                  | 568 |  |
|    | 26.8   | _               | ons                                             |     |  |
| 27 | Digita | al signa        | ture                                            | 570 |  |
|    | 27.1   |                 | ew                                              |     |  |
|    | 27.2   |                 | ct Unique Identification (UID) register (80bit) |     |  |
|    | 27.3   |                 | ct model register                               |     |  |
|    |        |                 |                                                 |     |  |
|    | 27.4   |                 |                                                 |     |  |
|    | 27.5   |                 | capacity register                               |     |  |
|    | 27.6   |                 | mber register                                   |     |  |
| 28 | Revis  | sion history572 |                                                 |     |  |



### 1 Documentation conventions

## 1.1 Typographical conventions

The typographical conventions used in this document are:

Italic Indicates a special term or citation, or prompts a note.

Bold Indicates a component or signal name, such as for title descriptions without chapter

numbers, titles for diagrams, etc.

English uppercase

Used for terms that have a specific technical meaning and are included in the

glossary, such as register or bit field names.

Color text Indicates a link. Including:

• URL external link, such as www.whxy.com

• Cross-references, internal chapters of this paper refer to each other

• Internal links, figures, tables or appendices, glossary entries



# 1.2 Register protocol

| Symbol example | Describe                                                                                                                                                   |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x53CA         | A numeric string prefixed with '0x' represents a hexadecimal number, and the value is composed of 0~9 or A~F.                                              |
| REGNAME[n]     | A specific bit of REGNAME, REGNAME can be a register or register field, for example, CR1[2] refers to bit 2 of the CR1 register (field).                   |
| REGNAME[m:n]   | A specific bit of REGNAME, REGNAME can be a register or a register field, for example, CR1[7:5] refers to the 7th to 5th bits of the CR1 register (field). |
| RW             | Read and write, software can read and write these bit fields.                                                                                              |
| RO             | Read-only, software can only read these bit fields.                                                                                                        |
| WO             | Write-only, software can only write to this bit field, and invalid data will be returned when reading this bit field.                                      |
| RW0            | Software can read and write this bit field, only 0 can be written to this bit field, and writing 1 has no effect on this bit field.                        |
| RW1            | Software can read and write this bit field, only 1 can be written to this bit field, and writing 0 has no effect on this bit field.                        |
| R0W1           | When the software reads this bit field as 0, only 1 can be written to this bit field, and writing 0 has no effect on this bit field.                       |
| R1W0           | When the software reads this bit field as 1, only 0 can be written to this bit field, and writing 1 has no effect on this bit field.                       |
| RFU            | Reserved bit field, please keep the default value.                                                                                                         |
| Word           | The data length of a word is 32 bits.                                                                                                                      |
| Half Word      | The data length of a half word is 16 bits.                                                                                                                 |
| Byte           | The data length of one byte is 8bit.                                                                                                                       |

## 2 System and memory overview

## 2.1 System architecture

The consists of CW32W031 microcontroller system contains:

- 2 master device:
  - ARM® Cortex®-M0+ core
  - General-purpose DMA
- Multiple slave device:
  - On-chip SRAM
  - On-chip FLASH
  - FLASH controller
  - CRC redundancy calculation unit
  - GPIO port
  - AHB to APB1 conversion bridge and all devices on the APB1 bus
  - AHB to APB2 conversion bridge and all devices on the APB2 bus
  - AHB to APB3 conversion bridge and all devices on the APB3 bus
  - AHB to APB4 conversion bridge and all devices on the APB4 bus

The master and slave devices are connected through AHB bus matrix, and the system architecture is shown as follows:



Figure 2-1 System architecture

- System bus
  - Realize the connection of peripheral bus and bus matrix of M0+ microprocessor.
- DMA bus
  - AHB bus and bus matrix connection for DMA.
- Bus matrix
  - Manages the access arbitration between M0+ microprocessor and DMA to FLASH, SRAM and all peripherals. The arbitration control adopts the round-robin scheduling algorithm to balance the load and ensure the bus utilization efficiency.
- AHB TO APB Bridge 1/2/3/4
  - Provides a fully synchronized connection from the AHB bus to the APB1/APB2/APB3/APB4 bus, that is, the bridge between the AHB and APB buses.



#### 2.2 Memory organization

#### 2.2.1 Overview

The CW32W031 core is a 32-bit ARM® Cortex®-M0+ microprocessor with a maximum addressing space of 4GB. The built-in program memory, data memory, peripherals and port registers of the chip are uniformly addressed in the same 4GB linear address space.

Bytes in memory are organized in little-endian format. The lowest byte data of a word storage space is the least significant bit of the word, and the highest byte data is the most significant bit. E.g.:

Store 0x1122 3344 in the memory space at address 0x2000 0000, the actual result is:

0x20000000 bytes store 0x44, 0x20000001 bytes store 0x33, 0x20000002 bytes store 0x22,

0x20000003 bytes store 0x11.

The system address allocation is shown in the figure below, RES is the reserved area.

0xFFFF FFFF RES 0xF0FF FFFF M0+ peripherials 0xE000 0000 0x4800 1400- 0x4800 17FF **GPIOF** 0x4800 0800- 0x4800 0BFF **GPIOC RES** 0x4800 17FF 0x4800 0400- 0x4800 07FF **GPIOB** AHB AHB 0x4800 0000- 0x4800 03FF **GPIOA** 0x4002 0000 CRC 0x4002 3000- 0x4002 33FF RES 0x4001 7FFF 0x4002 2000- 0x4002 23FF FLASH CTRL APB4 0x4002 0000- 0x4002 03FF DMA 0x4001 4000 0x4001 4C00- 0x4001 4FFF **AWT** APB3 APB4 0x4001 0000 0x4001 4800- 0x4001 4BFF BTIM1/2/3 RES 0x4000 7FFF 0x4001 3800- 0x4001 3BFF UART1 0x4001 3000- 0x4001 33FF SPI APB2 0x4000 4000 0x4001 2C00- 0x4001 2FFF ATIM APB3 APB1 0x4001 2800- 0x4001 2BFF VC/LVD 0x4000 0000 0x4001 2400- 0x4001 27FF ADC RES 0x4001 0000- 0x4001 03FF **SYSCTRL** 0x2000 1FFF 0x4000 5400- 0x4000 57FF I2C SRAM(8KB) APB2 0x4000 4800- 0x4000 4BFF UART3 0x2000 0000 UART2 0x4000 4400- 0x4000 47FF RES 0x0010 0BFF **IWDT** 0x4000 3000- 0x4000 33FF OTP(128B) 0x0010 0B80 0x4000 2C00- 0x4000 2FFF **WWDT** RES APB1 0x4000 2800- 0x4000 2BFF RTC 0x0010 09FF 0x4000 1000- 0x4000 13FF GTIM2 **Boot program** 0x4000 0400- 0x4000 07FF GTIM1 memory (2.5KB) 0x0010 0000 RES 0x0000 FFFF FLASH(64KB) 0x0000 0000

Figure 2-2 System address assignment

26 / 572 Rev 1.0

## 2.2.2 Memory map and register boundary addresses

The detailed starting address space allocation of on-chip memory and peripherals is shown in the following table:

Table 2-1 Memory and Peripheral Address Allocation

| Device or Bus       | Boundary address          | Size  | Peripherals         |
|---------------------|---------------------------|-------|---------------------|
| Main FLASH memory   | 0x0000 0000 - 0x0000 FFFF | 64KB  | Main FLASH          |
| Boot program memory | 0x0010 0000 - 0x0010 09FF | 2.5KB | BootLoader          |
| OTP memory          | 0x0010 0B80 - 0x0010 0BFF | 128B  | OTP                 |
| SRAM memory         | 0x2000 0000 - 0x2000 1FFF | 8KB   | SRAM                |
|                     | 0x4000 0400 - 0x4000 07FF | 1KB   | GTIM1               |
|                     | 0x4000 1000 - 0x4000 13FF | 1KB   | GTIM2               |
| APB1 Peripheral     | 0x4000 2800 - 0x4000 2BFF | 1KB   | RTC                 |
|                     | 0x4000 2C00 - 0x4000 2FFF | 1KB   | WWDT                |
|                     | 0x4000 3000 - 0x4000 33FF | 1KB   | IWDT                |
|                     | 0x4000 4400 - 0x4000 47FF | 1KB   | UART2               |
| APB2 Peripheral     | 0x4000 4800 - 0x4000 4BFF | 1KB   | UART3               |
|                     | 0x4000 5400 - 0x4000 57FF | 1KB   | I2C                 |
|                     | 0x4001 0000 - 0x4001 03FF | 1KB   | SYSCTRL             |
|                     | 0x4001 2400 - 0x4001 27FF | 1KB   | ADC                 |
| ADD2 Davinhaval     | 0x4001 2800 - 0x4001 2BFF | 1KB   | VC/LVD              |
| APB3 Peripheral     | 0x4001 2C00 - 0x4001 2FFF | 1KB   | ATIM                |
|                     | 0x4001 3000 - 0x4001 33FF | 1KB   | SPI                 |
|                     | 0x4001 3800 - 0x4001 3BFF | 1KB   | UART1               |
| ADD4 Davinh aval    | 0x4001 4800 - 0x4001 4BFF | 1KB   | BTIM1/2/3           |
| APB4 Peripheral     | 0x4001 4C00 - 0x4001 4FFF | 1KB   | AWT                 |
|                     | 0x4002 0000 - 0x4002 03FF | 1KB   | DMA                 |
|                     | 0x4002 2000 - 0x4002 23FF | 1KB   | FLASH CTRL          |
|                     | 0x4002 3000 - 0x4002 33FF | 1KB   | CRC                 |
| AHB Peripheral      | 0x4800 0000 - 0x4800 03FF | 1KB   | GPIOA               |
|                     | 0x4800 0400 - 0x4800 07FF | 1KB   | GPIOB               |
|                     | 0x4800 0800 - 0x4800 0BFF | 1KB   | GPIOC               |
|                     | 0x4800 1400 - 0x4800 17FF | 1KB   | GPIOF               |
| M0+ Peripheral      | 0xE000 0000 - 0xE00F FFFF | 1MB   | M0+ Core Peripheral |

## 2.3 On-chip SRAM memory

CW32W031 integrates 8KB on-chip SRAM, and the starting address is 0x2000 0000. SRAM supports access in 3 widths of byte (8bit), half word (16bit) or full word (32bit), and can be accessed by CPU and DMA at the maximum system clock frequency with zero latency.

#### Parity check

The SRAM supports the parity check function, which is enabled by default after the chip is powered on, and cannot be configured by the user.

The data bus of SRAM is 36 bits, including 32 bits of data bits and 4 bits of parity bits (each 8 bits of data bits is equipped with 1 bit of parity bits), which is used to increase the robustness of the memory.

The parity bits are computed and stored when the CPU writes to the SRAM, and they are automatically checked when reading. After the system detects that the parity check fails, it will generate the corresponding interrupt flag.

For a detailed introduction to SRAM, see chapter 6 RAM Memory.

#### 2.4 On-chip FLASH memory

The on-chip FLASH memory consists of two physical areas: the main FLASH memory and the boot program memory.

- Main FLASH memory, a total of 64KB, the address space is 0x0000 0000 0x0000 FFFF. This area is mainly used to store application code and user data, which is programmable by the user.
- Boot program memory, a total of 2.5KB, the address space is 0x0010 0000 0x0010 09FF. This area is mainly used to store the BootLoader startup program, which has been programmed when the chip leaves the factory and cannot be changed by the user.

The FLASH controller implements various operations on FLASH (erase, write, read).

FLASH supports access with 3 widths of byte (8bit), half word (16bit) or full word (32bit), and the highest frequency of access is 24MHz. If the HCLK clock frequency of the system configuration is higher than 24MHz, a reasonable response waiting time must be configured through the WAIT bit field of the FLASH control register FLASH CR2 to ensure that the FLASH is correctly accessed.

For a detailed introduction to FLASH, see chapter 7 FLASH Memory.

## 2.5 One-time programmable OTP memory

There is 128B memory space inside the chip as the OTP area, and the address space is 0x0010 0B80 – 0x0010 0BFF. This memory area can only be written to by ISP programming instructions, and can only be written once, and then can only be read, not erased and written. This area is mainly used to store unchangeable information, such as user-defined product UID, algorithm key, etc., which are written when the device leaves the factory.

## 2.6 System boot configuration

The device supports 2 different boot modes, which are selected by the BOOT pin state, as shown in the following table:

Table 2-2 Boot mode configuration

| Boot mode configuration | Mode                                                                                                                                                                                                                        |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BOOT = 0                | Boot from main FLASH memory, run user program.                                                                                                                                                                              |
| BOOT = 1                | Start from the boot program memory, and fix the BootLoader program of the running chip. At this time, the user can use the ISP communication protocol to perform FLASH programming through the UART1 interface (PA13/PA14). |

The boot mode selection circuit only samples the state of the BOOT pin when the chip is de-reset, so the user must set the level state of the BOOT pin as needed before the chip is de-reset to determine the startup mode after the chip is reset.

After the system is started, the CPU obtains the address of the top of the stack from the address 0x00000000 of the memory, and starts executing code from the address indicated by 0x00000004 of the memory.

The BootLoader program is located in the boot program memory area and is programmed by the equipment provider at production time. Users can use ISP communication protocol to perform FLASH programming through UART1 (pins are PA13/PA14).

#### 2.7 Precautions

CW32W031 needs to pay attention to the following matters when using:

- A few registers such as FLASH, SRAM and GPIOx\_ODR, CRC\_DR support 8bit/16bit/32bit access mode, and other peripherals only support 32bit access mode. 8bit/16bit access to an address that does not support 8bit/16bit access mode will generate a HardFault hardware error exception.
- The RES areas in the system address allocation in *Figure 2-2 System address assignment* are reserved address spaces without corresponding physical devices. If these reserved address spaces are accessed, a HardFault hardware error exception will occur.
- After the chip is reset, all peripheral clocks except SYSTICK and SRAM are turned off. Before using these peripherals, the user must pass the peripheral clock enable control register (AHB peripheral clock enable control register SYSCTRL\_AHBEN, APB peripheral clock Enable control register SYSCTRL\_APBEN1/2) to open the configuration clock and working clock of the corresponding peripheral. Failure to turn on the peripheral configuration clock will result in an access failure: writing data fails, and no HardFault hardware error exception will be generated, and the result of reading data is not available. If the operating clock of the peripheral is not turned on, the main function of the peripheral is invalid.

## 3 Power Control (PWR) and Power Consumption

#### 3.1 Overview

CW32W031 needs two sets of power supply when working: working power supply (VDD, VSS) and analog power supply (VDDA, VSSA). The user can choose to use the same power supply for the working power supply and the analog power supply, or use two different power supplies, but the difference between the two should not exceed 0.3V. Please refer to the relevant chapters of the datasheet for details of the power supply.

The independent power supply pin VDDRF powers the RF subsystem and must be connected to the same power supply as VDD.

CW32W031 embeds a 1.5V low dropout LDO voltage regulator to supply power to the digital power domain inside the chip.

The chip has a built-in reference voltage generator (BGR) circuit, which can provide reference voltage for other analog modules.

#### Caution:

The difference between the analog supply voltage and the reference voltage must be higher than 0.3V. Please refer to the relevant section of the datasheet for detailed parameters of the voltage reference.

The division and allocation of power domains within the chip are shown in the following figure:



Figure 3-1 System Power Distribution

## 3.2 Power supply supervisor

#### Power on reset (POR)/ Brown-out reset (BOR)

CW32W031 integrates power-on reset (POR) and Brown-out reset (BOR) power monitoring circuits, and is always in working state after power-on. POR/BOR monitors both the VDD and VDDA power supply voltages. When the monitored power supply voltage is lower than the reset threshold (V<sub>BOR</sub>), the system will enter the reset state. Users do not need to add an external hardware reset circuit.

The reset signal waveforms of the power-on and power-down phases are shown in the following figure:



Figure 3-2 Power on reset/power down reset waveform

For more details on the power on / power down reset threshold, refer to the electrical characteristics section in the datasheet.



34 / 572 Rev 1.0

#### 3.3 Operating mode

CW32W031 supports three operating modes, and the integrated power management module of the built-in power supply automatically completes the unified management. The three working modes are:

- Active mode
- Sleep mode
- DeepSleep mode

After the power is turned on, the system automatically enters the active mode. Users can enter two low-power operating states of sleep or deep sleep through software programs; In the low-power operating state, the wake-up mechanism can be triggered by a hardware interrupt to return the system to the active mode.

The conversion mechanism of the three operating modes is shown in the following figure:

Reset

Software program control

Active mode

Hardware interrupt wakeup

Software program control

Active mode

Hardware interrupt wakeup

Figure 3-3 The conversion mechanism of the operating modes

In the active mode, the CPU runs normally, and all module users can use it normally. In Sleep mode, the CPU stops running, all peripherals are unaffected, and all I/O pins remain in the same state. In DeepSleep mode, the CPU stops running, the high-speed clock (HSE, HSIOSC) is automatically turned off, and the low-speed clock (LSE, LSI, RC10K, RC150K) remains in the original state.

The CPU and clock states in different operating modes are shown in the following table:

Operating mode **CPU** state High-speed clock Low-speed clock Active mode Run ON/OFF ON/OFF Sleep mode ON/OFF ON/OFF Stop OFF DeepSleep mode Stop ON

Table 3-1 Operating mode and CPU and Clock States

# 3.3.1 Entering Sleep mode or DeepSleep mode

Using the M0+ core's ARM waits for interrupt-specific instruction, WFI (Wait for Interrupt), in conjunction with the SLEEPONEXIT and SLEEPDEEP bit fields of the M0+ core's system control register (SCR, System Control Register), Sleep mode or DeepSleep mode can be entered or exited immediately (interrupt service routine).

## Entering immediately

Executing the WFI instruction, the MCU will immediately enter Sleep mode (when SLEEPDEEP is 0) or DeepSleep mode (when SLEEPDEEP is 1)

# • Entering on exit

Setting the SLEEPONEXIT bit to 1, after exiting the lowest priority interrupt service routine, the MCU will enter Sleep mode (when SLEEPDEEP is 0) or DeepSleep mode (when SLEEPDEEP is 1), needn't execute the WFI instruction.

Table 3-2 Entering Sleep mode or DeepSleep mode

| Entry method     | SLEEPONEXIT bit | Condition                          | SLEEPDEEP bit | Enter mode     |
|------------------|-----------------|------------------------------------|---------------|----------------|
| Entering         |                 | Executing the WFI                  | 0             | Sleep mode     |
| immediately      | -               | instruction                        | 1             | DeepSleep mode |
|                  |                 | After exiting the lowest           | 0             | Sleep mode     |
| Entering on exit | 1               | priority interrupt service routine | 1             | DeepSleep mode |

#### Caution 1:

In DeepSleep mode, the system will automatically turn off the high-speed clock. If users need to keep some peripherals running in DeepSleep mode, they must start the corresponding low-speed clock and set the peripheral clock to this low-speed clock before entering DeepSleep mode.

#### Caution 2:

Before entering DeepSleep mode, if the FLASH is performing an erase/write operation, you must wait for the FLASH\_CR1.BUSY flag bit to clear to 0, and make sure FLASH\_CR1.MODE is 0 at the same time.



# 3.3.2 Exiting Sleep mode or DeepSleep mode

In Sleep mode or DeepSleep mode, the interrupt can be used to wake up the CPU and return to active mode. However, it is worth noting that if the user executes the WFI command in the interrupt service routine to enter Sleep (including DeepSleep), an interrupt with a higher priority than this interrupt is required to wake up the CPU, so we strongly recommend that the user is ready to enter sleep, all interrupt service routines should be processed and all interrupt requests and interrupt flags should be cleared.

In different operating modes, the types of interrupts that the CPU can respond to are shown in the following table:

Table 3-3 Operating Modes and Interrupt Sources

| Interrupt Number | Interrupt Sources | Active mode | Sleep mode | DeepSleep mode |
|------------------|-------------------|-------------|------------|----------------|
| 0                | IWDT              | Υ           | Υ          | Y              |
| 0                | WWDT              | Υ           | Υ          | N              |
| 1                | LVD               | Υ           | Υ          | Υ              |
| 2                | RTC               | Υ           | Υ          | Υ              |
| 3                | FLASH             | Υ           | Υ          | N              |
| 3                | RAM               | Υ           | Υ          | N              |
| 4                | RCC               | Υ           | Υ          | Υ              |
| 5                | GPIOA             | Υ           | Υ          | Υ              |
| 6                | GPIOB             | Υ           | Υ          | Υ              |
| 7                | GPIOC             | Υ           | Υ          | Υ              |
| 8                | GPIOF             | Υ           | Υ          | Υ              |
| 9                | DMA1              | Υ           | Υ          | N              |
| 10               | DMA2              | Υ           | Υ          | N              |
| 10               | DMA3              | Υ           | Υ          | N              |
| 11               | DMA4              | Υ           | Υ          | N              |
| 12               | ADC               | Υ           | Υ          | N              |
| 13               | ATIM              | Υ           | Υ          | N              |
| 14               | VC1               | Υ           | Υ          | Υ              |
| 15               | VC2               | Υ           | Υ          | Υ              |
| 16               | GTIM1             | Υ           | Υ          | N              |
| 17               | GTIM2             | Υ           | Υ          | N              |
| 20               | BTIM1             | Υ           | Υ          | N              |
| 21               | BTIM2             | Υ           | Υ          | N              |
| 22               | BTIM3             | Υ           | Υ          | N              |

| Interrupt Number | Interrupt Sources | Active mode | Sleep mode | DeepSleep mode |
|------------------|-------------------|-------------|------------|----------------|
| 23               | I2C               | Υ           | Υ          | N              |
| 25               | SPI               | Υ           | Υ          | N              |
| 27               | UART1             | Υ           | Υ          | Υ              |
| 28               | UART2             | Υ           | Υ          | Υ              |
| 29               | UART3             | Υ           | Υ          | Υ              |
| 30               | AWT               | Υ           | Υ          | Υ              |
| 31               | FAULT             | Υ           | Υ          | Υ              |

Exiting Sleep mode using an interrupt, the user must enable the enable bit for this interrupt before entering Sleep (including DeepSleep mode).

After the interrupt wakes up and exits Sleep mode, the CPU will immediately enter the interrupt service routine for this interrupt. If the user does not set this interrupt service routine, and when entering sleep immediately: the CPU will continue to execute the next statement of the WFI instruction that entered sleep; when entering sleep when exiting: continue to execute the next statement of the last entered interrupt service routine. In general, based on system reliability considerations, it is strongly recommended that the user set the service routine for this interrupt, and clear the interrupt request and interrupt flag in the interrupt service routine.

When the interrupt wakes up to exit the DeepSleep mode, the CPU operation state is the same as the exit from the Sleep mode.

In DeepSleep mode, the system will automatically turn off the high-speed clock. When exiting DeepSleep, CW32W031 adds an additional system clock option for users. Users can choose to continue to use the clock used when entering DeepSleep, or select HSI as the system clock. Configure the WAKEUPCLK bit field of the system control register SYSCTRL\_CR2 to 1, then the internal high-speed clock HSI is automatically used as the system clock after the interrupt wakes up and exits the DeepSleep mode. Since the recovery time of the HSI clock is faster than that of the HSE, it can speed up the system wake-up.

# 3.3.3 Operating Modes and Reset Sources

Even in Sleep mode or DeepSleep mode, the CPU can respond to some reset sources. The hardware reset or software reset that the CPU can respond to in different working modes is shown in the following table:

Table 3-4 Operating Modes and Reset Sources

| Reset Sources                            | Active mode | Sleep mode | DeepSleep mode |
|------------------------------------------|-------------|------------|----------------|
| Power-on reset/Brown-out reset (POR/BOR) | Υ           | Υ          | Υ              |
| Pin input reset (NRST)                   | Υ           | Υ          | Υ              |
| LVD reset                                | Υ           | Υ          | Υ              |
| IWDT reset                               | Υ           | Υ          | Y              |
| WWDT reset                               | Υ           | Υ          | N              |
| Kernel LOCKUP fault reset                | Υ           | N          | N              |
| Kernel SYSRESETREQ reset                 | Υ           | N          | N              |

# 3.4 Low-power consumption applied

In Sleep mode, the CPU stops running, and all peripherals keep running, including ARM®Cortex®-M0+ core peripherals, such as NVIC, SysTick and other peripherals. Sleep mode consumes less power than active mode.

In DeepSleep mode, the CPU stops running, the high-speed clock is turned off, the low-speed clock remains unchanged, some peripherals can be configured to continue to run, and the NVIC interrupt processing still works. DeepSleep mode consumes much less power than Sleep mode.

Users can reduce system running power consumption by:

# Decrease system clock frequency

- Use low-frequency high-speed clock HSI, HSE or low-speed clock LSI, LSE
- Reduce the frequency of SYSCLK, HCLK, PCLK by programming the prescaler registers
  - Set the SYSCLK bit field of the SYSCTRL\_CR0 register to select the appropriate clock source
  - Set the HCLKPRS bit field of the SYSCTRL\_CR0 register to reduce the HCLK frequency
  - Set the PCLKPRS bit field of the SYSCTRL\_CR0 register to reduce the PCLK frequency

# Turn off clocks and peripherals which not in use during sleep

- AHB bus clock HCLK and APB bus clock PCLK, can be turned off as needed
- Turn off clocks to peripherals not related to wakeup
  - AHB peripheral clock enable control register, SYSCTRL\_AHBEN
  - APB peripheral clock enable control register 1, SYSCTRL\_AHBEN1
  - APB peripheral clock enable control register 2, SYSCTRL\_AHBEN2

# 3.5 Cortex®-M0+ kernel system control register (SCB->SCR)

Address: 0xE000 ED10 Reset value: 0x0000 0000

| Bit filed | Name        | Permission | Function description                                                                                                                                                                                                       |
|-----------|-------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5      | RFU         | -          | Reserved bits, please keep the default value                                                                                                                                                                               |
| 4         | SEVONPEND   | RW         | When set to 1, each new suspension of an interrupt generates an event, which can be used to wake up the processor if WFE sleep is used.                                                                                    |
| 3         | RFU         | -          | Reserved bits, please keep the default value                                                                                                                                                                               |
| 2         | SLEEPDEEP   | RW         | When set to 1, enter DeepSleep mode when WFI or SLEEPONEXIT is 1 and all interrupt service routines are exited; When set to 0, enter Sleep mode when WFI or SLEEPONEXIT is 1 and all interrupt service routines are exited |
| 1         | SLEEPONEXIT | RW         | When set to 1, the processor automatically enters Sleep mode (or DeepSleep mode) when all interrupt service routines are exited; When set to 0, the hibernation function on exit is disabled                               |
| 0         | RFU         | -          | Reserved bits, please keep the default value                                                                                                                                                                               |

# 4 Reset and clock control (RCC)

# 4.1 System reset

CW32W031 supports the following 6 system resets:

- Power on reset (POR)/ Brown-out reset (BOR)
- Pin input reset (NRST)
- IWDT/WWDT reset
- LVD reset
- Kernel SYSRESETREQ reset
- Kernel LOCKUP reset

The reset range of each system reset is shown in the following table:

Table 4-1 Reset method and range

| Reset method                                | Reset range                                                                    |
|---------------------------------------------|--------------------------------------------------------------------------------|
| Power on reset (POR)/ Brown-out reset (BOR) | Entire MCU                                                                     |
| Pin input reset (NRST)                      | Entire MCU (Except RTC)                                                        |
| IWDT/WWDT reset                             | M0+ core/peripheral (Except RAM controller/RTC)                                |
| LVD reset                                   | M0+ core/peripheral (Except LVD controlle section/RTC)                         |
| Kernel SYSRESETREQ reset                    | M0+ core (Except SWD debug logic) / Peripheral (Except RAM controller/LVD/RTC) |
| Kernel LOCKUP fault reset                   | M0+ core/peripheral (Except RAM controller/LVD/RTC)                            |

After the system reset occurs, the CPU runs again, most of the registers are reset to default values, and the program starts to execute from the reset interrupt entry address of the interrupt vector table.

The user can query the reset source of this system reset through the system reset flag register SYSCTRL\_RESETFLAG. The reset flag is set by hardware and cleared by software. It is recommended that users clear the relevant flag bits of this register to 0 after reading the flag bits to avoid confusion after the next reset.

# 4.1.1 Power on reset/Brown-out reset (POR/BOR)

The CW32W031 integrates special POR and BOR circuits to monitor the power supply voltage, and keeps the chip in the reset state when the power supply voltage is lower than the safe range to prevent the chip from malfunctioning during power-on/power-off. In order to ensure the stable operation of the system, the user must keep the power supply voltage within a safe range.

For the specific functions of POR and BOR, please refer to chapter *3 Power Control (PWR) and Power Consumption*.

### Caution:

In order to ensure that the chip works normally after the reset is released, the circuit design must ensure that VDD/VDDA are powered on and off at the same time.



## 4.1.2 Pin input reset (NRST)

CW32W031 has a special reset input pin, inputting a low-level signal of a certain width will cause the system to reset. A dedicated anti-shake circuit is designed inside the chip, and low-level pulse signals shorter than  $20\mu s$  will be shielded.

The reset input pin has a built-in pull-up resistor. If the user needs to connect an external RC circuit, the influence of the internal pull-up resistor must be considered. For the circuit characteristics of the built-in pull-up resistor, please refer to the relevant section of the datasheet.

## 4.1.3 IWDT/WWDT reset

The CW32W031 integrates an independent watchdog (IWDT) and a window watchdog (WWDT). When the IWDT or WWDT meets the reset condition, a reset signal will be generated to cause a system reset.

For detailed functions of IWDT and WWDT reset, please refer to chapters 16 Independent watchdog timer (IWDT) and 17 Window watchdog timer (WWDT).

# 4.1.4 LVD low voltage detection reset

The CW32W031 integrates a low voltage detector (LVD), which can continuously compare the selected monitoring voltage with the set LVD threshold voltage. When the comparison result meets the trigger condition, an LVD reset signal will be generated to cause a system reset.

Compared with the POR/BOR reset method, the LVD low voltage detection reset function is more powerful. The reset threshold voltage, monitoring voltage source, pulse filter width and hysteresis time can be set through the relevant registers.

See chapter 24 Low voltage detector (LVD) for LVD details.

### 4.1.5 Kernel SYSRESETREQ reset

The core SYSRESETREQ reset is a software reset, which is implemented by setting the SYSRESETREQ bit field of the Application Interrupt and Reset Control Status Register (AIRCR) of the ARM® Cortex®-M0+. Setting this bit to 1 by the application program will generate a core SYSRESETREQ reset, thereby implementing a software reset.

#### 4.1.6 Kernel LOCKUP fault reset

When the CPU encounters a serious exception (such as the read instruction is invalid, the bit width does not match the target address when accessing FLASH), it will stop the PC pointer at the current address and lock it, and generate the kernel LOCKUP fault reset signal.

After the chip is powered on, the LOCKUP reset function is disabled by default, and the user needs to manually enable it. By setting the LOCKUP bit field of the system control register SYSCTRL\_CR2 to 1, the LOCKUP reset function can be enabled.



# 4.2 Peripheral reset

Users can use software to reset various peripherals inside CW32W031 individually. Peripheral reset can restore the registers, state machines and various control logic of each peripheral to the default state after power-on reset. The user can perform the independent reset operation of each peripheral module by setting the three registers: SYSCTRL\_AHBRST, SYSCTRL\_APBRST1, and SYSCTRL\_APBRST2.

For power-on reset/brown-off reset (POR/BOR), the internal peripheral modules are already in the default state after reset, and the module can be initialized and configured directly, and there is no need to independently reset each module.

For other types of system resets, some peripherals may retain the working state before the reset. If the user needs to restore the peripherals to the default state of power-on, they should reset the peripherals through the corresponding reset registers before using them. The RTC module is a typical peripheral that may need to retain the current state after reset. For specific judgment logic examples, please refer to the relevant routines.

# 4.3 Clock and Control

#### 4.3.1 Overview

The CW32W031 has a built-in multi-channel clock generation circuit, which generates various clocks of different frequencies through the frequency divider and multiplexer for use by the CPU and various peripherals. The schematic diagram of the system clock tree structure is shown in the *Figure 4-1 System internal clock tree*.

The internal clock SysClk of the system is divided to provide the advanced high-performance bus clock HCLK for the CPU core, and the HCLK clock is divided to provide the advanced peripheral clock PCLK for digital and analog peripherals.

System clock SYSCLK has 4 clock sources:

- High-speed external oscillator clock (HSE)
- Low-speed external oscillator clock (LSE)
- The HSI clock is generated by dividing the internal high-speed RC oscillator clock (HSIOSC)
- Low-speed internal RC oscillator clock (LSI)

The system internal clock tree is shown in the following figure:



Figure 4-1 System internal clock tree

The high-speed internal RC oscillator clock HSIOSC is divided by the frequency divider to generate the HSI clock. The frequency division coefficient is set through the DIV bit field of the built-in high-frequency clock control register SYSCTRL\_HSI, and the effective frequency division coefficients are 1, 2, 4, 6, 8, 10, 12, 14, and 16.

The system clock SysClk can be selected from 4 clock sources: HSE, LSE, HSI, LSI, which can be selected by the SYSCLK bit field of the system control register SYSCTRL\_CRO.

Advanced high-performance bus clock HCLK is generated by the frequency division of the system clock SysClk, and is used as the configuration clock and working clock of the M0+ core, SysTick, DMA, FLASH, CRC, GPIO and other modules. The frequency division factor is set by the HCLKPRS bit field of the system control register SYSCTRL\_CRO, and the effective frequency division factor is  $2^n$  (n = 0~7).

Advanced peripheral clock PCLK, which is generated by frequency division of HCLK, is used as the configuration clock and working clock of peripherals such as timer, SPI, and I2C. The frequency division factor is set by the PCLKPRS bit field of the system control register SYSCTRL\_CR0, and the effective frequency division factor is  $2^n$  (n =  $0\sim3$ ).

In addition to the 4 clock sources used as the system clock, the CW32W031 also has 3 dedicated clock sources:

- Internal RC10K clock
   Can be used as IWDT module count clock and filter clock for GPIO port interrupt input signal.
- Internal RC150K clock
   Can be used as the filter clock of the digital filter module of LVD and VC, and the filter clock of the GPIO port interrupt input signal.
- External 32MHz oscillator clock Independent dedicated crystal oscillator clock that can be used as the operating clock for the RF system.

### 4.3.2 System Clock and Operating Mode

CW32W031 supports three operating modes: Active mode, Sleep mode and DeepSleep mode.

In the Active mode, the CPU runs normally, and all module users can use it normally.

In the Sleep mode, the CPU stops running, and the clock oscillators and peripherals remain unchanged.

In DeepSleep mode, the CPU stops running, and the high-speed clock HSE, HSIOSC oscillator are automatically turned off to save power; The oscillators of the low-speed clocks LSE, LSI, RC10K, RC150K remain unchanged; Whether the system clock SysClk and the HCLK and PCLK clocks are valid depends on the clock source status of the SysClk system clock.

After waking up from DeepSleep mode, if the WAKEUPCLK bit field of the system control register SYSCTRL\_CR2 is configured as 1, the system will automatically use the HSI as the clock source of the system clock. If SYSCTRL\_CR2.WAKEUPCLK is 0, the system will wait for the system clock source used before the system enters deep sleep to stabilize before starting to run; If the clock source of the system clock is HSE, the clock recovery speed and system response speed will be slower. Since the HSI starts up quickly and can quickly respond to user needs, it is recommended to switch the clock source of the system clock to the HSI clock or configure SYSCTRL\_CR2.WAKEUPCLK to 1 before entering DeepSleep mode.

#### 4.3.3 HSE clock

The high-speed external clock signal (HSE) supports two operating modes:

- For crystal/ceramic resonators, set the MODE bit field of the external high-frequency crystal control register SYSCTRL\_HSE to 0, and configure the OSC\_IN and OSC\_OUT pins as analog functions.
- For external clock input, set the MODE bit field of the external high-frequency crystal control register SYSCTRL\_HSE to 1, and configure the OSC\_IN pin as a digital input function.

Table 4-2 HSE operating mode configuration

| Work mode                  | SYSCTRL_HSE.MODE | OSC_IN        | OSC_OUT                             |
|----------------------------|------------------|---------------|-------------------------------------|
| Crystal/Ceramic resonators | 0                | Analog        | Analog                              |
| External clock input       | 1                | Digital input | Can be used as general purpose GPIO |

## Crystal/Ceramic resonators clock mode

The external quartz crystal/ceramic resonator is connected between the OSC\_IN and OSC\_OUT pins, and cooperates with the start-up capacitor to generate a stable 4~32MHz clock signal. The circuit connection is shown in the following figure:

Figure 4-2 HSE external quartz crystal/ceramic resonator connection method



The crystal/ceramic resonator and start-up capacitor must be placed as close as possible to the chip oscillator pins to minimize oscillator output distortion and start-up time.

The value of the start-up capacitor must be adjusted according to the selected crystal/ceramic resonator. The calculation method is:

$$C_1 = (C_{11} \times C_{12}) / (C_{11} + C_{12}) + C_0$$

Among them,

C<sub>L</sub> is the nominal load capacitance of the crystal;

 $C_0$  is the stray capacitance value, which is related to the design of the circuit board. Generally, the value can be 4pF ~ 6pF;

 $C_{L1}$  and  $C_{L2}$  are two external start-up capacitors, usually  $C_{L1}$  and  $C_{L2}$  are same;

If the user uses a crystal resonator with a nominal load capacitance value of 12.5pF, the common value of the two external starting capacitors for the crystal is 15pF.



#### Caution:

Since there are many crystal manufacturers, the crystal characteristics of each manufacturer are different. If the output clock signal of the HSE oscillator is not ideal, you can contact the crystal supplier for coordination.

In order to ensure the performance of the HSE oscillator, it is necessary to set the FREQRANGE bit field of the external high-frequency crystal control register SYSCTRL\_HSE according to the nominal frequency of the external crystal, as shown in the following table:

External crystal nominal frequency

SYSCTRL\_HSE.FREQRANGE

4MHz ~ 8MHz

00

8MHz ~ 16MHz

16MHz ~ 24MHz

24MHz

11

Table 4-3 HSE external crystal frequency setting

The user can adjust the drive capability by setting the DRIVER bit field of the external high-frequency crystal control register SYSCTRL\_HSE. There are four levels of drive capability to choose from. The stronger the drive capability, the higher the power consumption. Users can balance clock reliability, startup time, and low power consumption as needed.

# External clock input mode

In the external clock input mode, the external clock is input from the OSN\_IN pin, and the OSC\_OUT pin can be used as a general-purpose GPIO. The input clock signal can be square wave, sine wave or triangular wave, the duty cycle must be between 40%~60%, and the frequency is between 4~32MHz.

In the two working modes of HSE, the HSE clock oscillator is turned off by default after power-on, and is enabled by setting the HSEEN bit field of the system control register SYSCTRL\_CR1 to 1.

After the HSE oscillator is started, when the internal clock monitoring module of the chip detects a certain number of HSE clock signals, the HSE clock is considered to be stable. The number of detection clocks can be set through the WAITCYCLE bit field of the external high-frequency crystal control register SYSCTRL\_HSE, as shown in the following table:

| SYSCTRL_HSE.WAITCYCLE | Number of HSE detection clocks |
|-----------------------|--------------------------------|
| 00                    | 8192                           |
| 01                    | 32768                          |
| 10                    | 131072 (Defaults)              |
| 11                    | 262144                         |

Table 4-4 HSE Stability Detection Clock Signal Number

The start-up state of the HSE clock can be determined through the STABLE flag of the external high-frequency crystal control register SYSCTRL\_HSE. If the STABLE flag is 1, the HSE clock is stable, and if it is 0, the HSE clock is not stable.

## Caution:

All parameters of the HSE oscillator should be set before starting, and it is forbidden to modify the relevant parameters after starting.



#### 4.3.4 HSIOSC clock

The HSIOSC clock is generated by the internal RC oscillator, no external circuit is required, the cost is lower than the HSE clock, and the startup speed is faster. The HSIOSC clock frequency is fixed at 48MHz, and the frequency accuracy is lower than that of the HSE clock.

The frequency of the RC oscillator output clock is affected by the chip processing process, operating voltage, ambient temperature and other factors. CW32W031 provides the HSIOSC clock frequency calibration function. Users can calibrate the HSIOSC clock by setting the TRIM bit field value of the built-in high-frequency clock control register SYSCTRL\_HSI frequency, see section *4.4.2 Clock calibration* for details.

The HSIOSC internal high-speed RC oscillator is turned on by default after the chip is powered on. Users can turn it off by setting the HSIEN bit field of SYSCTRL\_CR1 in the system control register to 0. If the user stops and restarts the HSIOSC oscillator, the STABLE flag of the built-in high-frequency clock control register SYSCTRL\_HSI can be used to determine whether the HSI clock is stable. If the STABLE flag is 1, it means that the HSIOSC clock is stable, and if it is 0, it means that the HSIOSC clock is not stable yet.

#### Caution:

All parameters of the HSIOSC oscillator should be set before starting, and it is forbidden to modify the relevant parameters after starting.

The HSIOSC clock outputs the HSI clock after frequency division. The frequency division coefficient is set by the DIV bit field of the built-in high-frequency clock control register SYSCTRL\_HSI. The effective frequency division coefficients are 1, 2, 4, 6, 8, 10, 12, 14, 16, The default value after power-on is 6, so the default frequency of the HSI clock is 8MHz.

#### 4.3.5 LSE clock

External low-speed clock (LSE) supports two operating modes:

- For crystal/ceramic resonators, set the MODE bit field of the external low-frequency crystal control register SYSCTRL\_LSE to 0, and configure the OSC32\_IN and OSC32\_OUT pins as analog functions.
- For external clock input, set the MODE bit field of the external low-frequency crystal control register SYSCTRL\_LSE to 1, and configure the OSC32\_IN pin as a digital input function.

|                            |                  | o .           |                                     |
|----------------------------|------------------|---------------|-------------------------------------|
| Operating mode             | SYSCTRL_LSE.MODE | OSC32_IN      | OSC32_OUT                           |
| Crystal/Ceramic Resonators | 0                | Analog        | Analog                              |
| External clock input       | 1                | Digital input | Can be used as general purpose GPIO |

Table 4-5 LSE operating mode configuration

## Crystal/Ceramic resonators clock mode

The external low-frequency quartz crystal/ceramic resonator is connected between the two pins of OSC32\_IN and OSC32\_OUT. With the start-up capacitor, a stable clock signal of up to 1MHz can be generated. LSE is usually used as the operating clock of the system real-time clock RTC. At this time, a quartz crystal/ceramic resonator with a frequency of 32.768kHz should be selected. The external circuit connection is shown in the figure below:

OSC32\_IN OSC32\_OUT

CL1

CL2

Start-up capacitor

Figure 4-3 LSE external quartz crystal/ceramic resonator connection method

The quartz crystal/ceramic resonator and start-up capacitor must be placed as close as possible to the chip oscillator pins to minimize oscillator output distortion and start-up time.

The value of the start-up capacitor must be adjusted according to the selected crystal/ceramic resonator. The calculation method is:

$$C_{L} = (C_{L1} \times C_{L2}) / (C_{L1} + C_{L2}) + C_{0}$$

Among them,

C<sub>1</sub> is the nominal load capacitance of the crystal;

 $C_0$  is the stray capacitance value, which is related to the design of the circuit board. Generally, the value can be  $4pF\sim6pF$ ;

 $C_{L1}$  and  $C_{L2}$  are two external start-up capacitors, usually  $C_{L1}$  and  $C_{L2}$  are same;



51 / 572 Rev 1.0

If the user uses a crystal resonator with a nominal load capacitance value of 12.5pF, the common value of the two external starting capacitors for the crystal is 15pF.

#### Caution:

Since there are many crystal manufacturers, the crystal characteristics of each manufacturer are different. If the output clock signal of the LSE oscillator is not ideal, you can contact the crystal supplier for coordination.

Users can adjust the drive capability by setting the DRIVER bit field of the external low-frequency crystal control register SYSCTRL\_LSE. There are four levels of drive capability to choose from. The stronger the drive capability, the higher the power consumption. The amplitude of the clock signal can be adjusted by setting the AMP bit field of the external low-frequency crystal control register SYSCTRL\_LSE. There are four amplitudes to choose from. The larger the amplitude, the greater the power consumption. Users can balance clock reliability, startup time, and low power consumption as needed.

## External clock input mode

In the external clock input mode, the external clock is input from the OSN32\_IN pin, and the OSC32\_OUT pin can be used as a general-purpose GPIO. The input clock signal can be square wave, sine wave or triangular wave, the duty cycle must be between 45%~55%, and the frequency can be up to 1MHz.

In the two working modes of HSE, the LSE clock oscillator is turned off by default after power-on, and is enabled by setting the LSEEN bit field of the system control register SYSCTRL\_CR1 to 1.

After the LSE oscillator is started, when the internal clock monitoring module of the chip detects a certain number of LSE clock signals, the LSE clock is considered to be stable. The number of detection clocks can be set through the WAITCYCLE bit field of the external low-frequency crystal control register SYSCTRL\_LSE, as shown in the following table:

 SYSCTRL\_LSE.WAITCYCLE
 Number of LSE detection clocks

 00
 256

 01
 1024

 10
 4096 (Defaults)

 11
 16384

Table 4-6 LSE Stability Detection Clock Signal Number

The start-up state of the LSE clock can be determined through the STABLE flag of the external low-frequency crystal control register SYSCTRL\_LSE. If the STABLE flag is 1, the LSE clock is stable, and if it is 0, the LSE clock is not stable.

#### Caution:

All parameters of the LSE oscillator should be set before starting, and it is forbidden to modify the relevant parameters after starting.

The LSE oscillator has a lock function. After the lock function is turned on, the software is prohibited from clearing the enable bit (SYSCTRL\_CR1.LSEEN) of the LSE clock oscillator. That is, once the LSE is turned on, it cannot be turned off by software. The locking function is mainly designed to meet the requirements of some special application scenarios, such as application scenarios sensitive to RTC time loss, which can effectively prevent RTC time loss caused by misoperation. The lock function is disabled by default and is enabled by setting the LSELOCK bit field of the system control register SYSCTRL\_CR1 to 1.



#### 4.3.6 LSI clock

The LSI clock is generated by the internal low-speed RC oscillator with a default frequency of 32.8kHz. The internal low-speed RC oscillator requires no external circuitry and is less expensive than the LSE clock, but less accurate than the LSE clock.

The frequency of the RC oscillator output clock is affected by the chip processing process, operating voltage, ambient temperature and other factors. CW32W031 provides the LSI clock frequency calibration function. Users can calibrate the LSI clock frequency by setting the value of the TRIM bit field of the built-in low-frequency clock control register SYSCTRL\_LSI. For details, please refer to 4.4.2 Clock calibration.

The LSI internal low-speed RC oscillator is disabled by default, and is enabled by setting the LSIEN bit field of the system control register SYSCTRL\_CR1 to 1. After the LSI oscillator is started, if the internal clock monitoring module of the chip detects a certain number of LSI clock signals, the LSI clock is considered to be stable. The number of detection clocks can be set by the WAITCYCLE bit field of the built-in low-frequency oscillator control register SYSCTRL\_LSI, as shown in the following table:

| SYSCTRL_LSI.WAITCYCLE | Number of LSI detection clocks |
|-----------------------|--------------------------------|
| 00                    | 6 (Defaults)                   |
| 01                    | 18                             |
| 10                    | 66                             |
| 11                    | 258                            |

Table 4-7 LSI Stability Detection Clock Signal Number

The STABLE flag of the built-in low-frequency clock control register SYSCTRL\_LSI can be used to determine whether the LSI clock is stable. If the STABLE flag is 1, it means that the LSI clock is stable, and if it is 0, it means that the LSI clock is not stable.

#### Caution:

All parameters of the LSI oscillator should be set before starting, and it is forbidden to modify the relevant parameters after starting.

#### 4.3.7 RF clock

A built-in independent 32MHz dedicated crystal oscillator provides the operating clock for the RF system. The requirements for the external crystal are as follows:

- 1. Crystal frequency of 32MHz;
- 2. ESR less than 50ohm;
- 3. Crystal load capacitance less than or equal to 12pF;
- 4. Crystal frequency error less than or equal to 10ppm.

# 4.3.8 SysClk system clock

System clock SysClk can choose from 4 clock sources, including HSE, LSE, HSI, and LSI.

After the system power-on reset is completed, HSI is selected as the clock source of SysClk by default, and the default value of the clock frequency is 8MHz.

The user can select the system clock source through the SYSCLK bit field of the system control register SYSCTRL\_CR0. After selecting a clock as the system clock source, the user cannot stop the clock by setting the enable bit SYSCTRL\_CR1.xxxEN of the clock circuit to 0.

## 4.3.9 On-chip peripheral clock control

On-chip peripherals generally need the configuration clock and the working clock. The configuration clock is used to respond to the read and write operations of the peripheral registers by the CPU. The working clock is used for the function realization of each peripheral (such as the transmission clock of the UART, the count clock of the timer, etc.).

The configuration clock and working clock of the peripheral must be turned on before using the peripheral, otherwise the peripheral cannot work. By setting the corresponding bits of the AHB peripheral clock enable control register SYSCTRL\_AHBEN and the APB peripheral clock enable control register SYSCTRL\_APBEN1 and SYSCTRL\_APBEN2 to 1, the configuration clock and working clock of the corresponding peripherals are turned on.

Peripherals such as RTC, UART, AWT, and FLASH only open the configuration clock, and the working clock is configured through the clock source selection register of each module.

When the peripherals do not need to be used, the peripherals can be disabled by turning off the configuration clocks and operating clocks of the peripherals, which can effectively reduce the power consumption of the chip.



# 4.4 Clock Start, Calibration, and Status Detection

#### 4.4.1 Clock start

The clock source startup process of CW32W031 is similar. Take HSE as an example to illustrate the stabilization process after clock startup, as shown in the following figure:



Figure 4-4 HSE clock startup process

When SYSCTRL\_CR1.HSEEN is set to 1, the HSE clock oscillation circuit starts to work, but the output clock signal amplitude is very small at this time. After the start-up time stage, the amplitude and duty cycle of the output clock signal can meet the needs of the internal sampling circuit and enter the stabilization time stage. In the stable time stage, the internal clock monitoring circuit of the chip counts the clock signals output by the HSE. When the count value reaches the set number, the HSE clock signal is considered to be stable, and the HSE clock stability flag bit SYSCTRL\_HSE.STABLE is set to 1; If SYSCTRL\_HSE.WAITCYCLE clock signals are not detected within a certain period of time, it is considered that the HSE oscillator fails to start-up.

The clock start-up process of other clock oscillators is similar, but note that the number of detection clocks in the stable phase, the detection time and the number of detection clocks for start-up failure detection are different for each clock oscillator. For details, see the description of each clock oscillator.

#### 4.4.2 Clock calibration

Clock calibration is mainly for HSIOSC clock and LSI clock. Clock frequency calibration is achieved by adjusting the TRIM value of the oscillator.

#### **HSIOSC** clock calibration

The safe working range of HSIOSC is 32~48MHz. If it exceeds the safe range, the chip may be abnormal. When the chip leaves the factory, the calibration parameters of the 48MHz frequency point have been pre-adjusted and stored in FLASH. The application program only needs to read and write the calibration value in FLASH to SYSCTRL\_HSI.TRIM to obtain a precise 48MHz clock. The storage address of the 48MHz frequency calibration value is: 0x0010 0A00 – 0x0010 0A01. If other frequency clocks are needed, users need to adjust the value of SYSCTRL\_HSI.TRIM by themselves.

#### LSI clock calibration

The LSI output clock frequency range is  $32.8 \text{kHz} \pm 10\%$ . If the LSI output clock frequency is adjusted outside this range, the clock may be abnormal. When the chip leaves the factory, the calibration parameters of the 32.8 kHz frequency point are pre-adjusted and stored in the FLASH. The application program only needs to read the calibration value in the FLASH and write it into SYSCTRL\_LSI.TRIM to obtain an accurate 32.8 kHz frequency calibration value storage address:  $0x0010\ 0A02$  -  $0x0010\ 0A03$ . If other frequency clocks are needed, users need to adjust the value of SYSCTRL\_LSI.TRIM by themselves.



#### 4.4.3 Clock state detection

The chip has the functions of clock stability detection, start-up failure detection, and clock failure detection during clock startup, and supports automatic clock source switching when the currently selected system clock source fails.

# 4.4.3.1 Clock stability detection

The 5 clock sources, HSE, LSE, HSIOSC, and LSI, all support the clock stability detection function. Users can determine the clock status through the stability flag of the corresponding clock source. The clock stable flag is cleared by hardware when the clock source is turned off, and set 1 by hardware after the clock source is enabled and stable.

Note that the clock stable flag is only for the clock start-up process. During the clock stable operation process, the detection of clock operation failure will not affect the clock stable flag.

Taking the HSE clock source as an example, the HSE clock stability flag and clock stability interrupt flag are described as follows:

- SYSCTRL HSE.STABLE
  - Cleared by hardware when HSE is turned off, and set by hardware when it detects that the HSE clock is stable.
- SYSCTRL\_ISR.HSESTABLE
  - It belongs to the same signal as SYSCTRL\_HSE.STABLE. Although this signal is located in the interrupt flag register SYSCTRL\_ISR, it will not cause an interrupt request after being set to 1 by hardware.
- SYSCTRL ISR.HSERDY
  - When the hardware detects that the clock changes from an unstable state to a stable state (that is, the SYSCTRL\_HSE.STABLE flag changes from 0 to 1), it is set to 1, which is the clock stability interrupt flag. Users can clear this flag by setting SYSCTRL\_ICR.HSERDY to 0.



## 4.4.3.2 Clock start-up failure detection

CW32W031 supports external clock (HSE and LSE) start-up failure detection function. After the external clock is started, the clock detection logic counts the detected clock signals, and if a set number of clock signals are detected within the detection time, the clock starts to vibrate successfully, otherwise the start-up fails.

The number of clocks for HSE start-up failure detection is set through SYSCTRL\_HSE.WAITCYCLE. The detection time does not need to be set by the user, but is automatically set by the system, as shown in the following table:

 SYSCTRL\_HSE.WAITCYCLE
 Detection time
 Number of detection clocks

 00
 65ms
 8192

 01
 65ms
 32768

 10
 65ms
 131072

 11
 130ms
 262144

Table 4-8 HSE start-up failure detection time and number of detection clocks

he number of clocks for LSE start-up failure detection is set through SYSCTRL\_LSE.WAITCYCLE. The detection time does not need to be set by the user, but is automatically set by the system, as shown in the following table:

| SYSCTRL_LSE.WAITCYCLE | Detection time | Number of detection clocks |
|-----------------------|----------------|----------------------------|
| 00                    | 1s             | 256                        |
| 01                    | 1s             | 1024                       |
| 10                    | 1s             | 4096                       |
| 11                    | 25             | 16384                      |

Table 4-9 LSE start-up failure detection time and number of detection clocks

The external clock (HSE and LSE) failure detection function is disabled by default, and the corresponding interrupt flag will not be generated if the HSE/LSE fails to start. By setting SYSCTRL\_CR1.HSECCS to 1 and SYSCTRL\_CR1.LSECCS to 1, enable the fault detection function of the HSE and LSE external clocks respectively.

After enabling the fault detection function of the external clock, if the HSE or LSE fails to start, a start-up failure interrupt flag will be generated (corresponding to SYSCTRL\_ISR.HSEFAIL or SYSCTRL\_ISR.LSEFAIL is set to 1); if the interrupt is enabled (corresponding to SYSCTRL\_IER.HSEFAIL or SYSCTRL\_IER. LSEFAIL is set to 1), the CPU will execute the interrupt service routine to handle the failure of clock start-up.

# 4.4.3.3 In-flight failure detection of clocks

CW32W031 supports external clock (HSE and LSE) in-flight detection function. During the stable operation of the external clock, the clock detection logic continues to count the HSE and LSE clock signals with a certain detection period: if a set number of clock signals are detected within the detection period, the operation is normal, otherwise the operation fails.

The running failure detection period of the HSE clock is configured by SYSCTRL\_HSE.DETCNT, the actual time is SYSCTRL\_HSE.DETCNT/ $f_{LSI}$ , and the number of detection clocks is 0x20000. Considering that the clock has a certain deviation, in order to ensure the reliability of the detection function, the configuration of the HSE detection period parameter HSE.DETCNT must leave a certain margin, generally according to the operating frequency of the HSE, the configuration is  $8000/f_{HSE}$  (where  $f_{HSE}$  is the HSE clock frequency in MHz).

Example: If the HSE clock frequency is 4MHz, then SYSCTRL\_HSE.DETCNT should be configured as 2000.

The running failure detection period of the LSE clock is not configurable, it is fixed at 256 LSI clock periods, and the number of detection clocks is 128.

The external clock failure detection function is disabled by default, and the corresponding interrupt flag will not be generated if the HSE/LSE fails during operation. By setting SYSCTRL\_CR1.HSECCS to 1 and SYSCTRL\_CR1.LSECCS to 1, the HSE and LSE clock fault detection functions are enabled respectively. HSE or LSE clock running failure detection also needs to set SYSCTRL\_CR1.LSIEN to 1 to enable the internal low-speed clock LSI.

After the fault detection function of the external clock is enabled, if the HSE or LSE failure is detected during operation, a running failure flag will be generated (corresponding to SYSCTRL\_ISR.HSEFAULT or SYSCTRL\_ISR.LSEFAULT is set to 1), if the interrupt is enabled (corresponding to SYSCTRL\_IER. HSEFAULT or SYSCTRL\_IER.LSEFAULT is set to 1), the CPU will execute the interrupt service routine to handle the failure during clock operation.

If the current system clock source is HSE, set SYSCTRL\_CR1.CLKCCS to 0, no action when HSE is running and fail; set SYSCTRL\_CR1.CLKCCS to 1, system clock source will automatically switch to HSI clock when HSE is running and fail.

If the current system clock source is LSE, set SYSCTRL\_CR1.CLKCCS to 0, no action when LSE is running and fail; set SYSCTRL\_CR1.CLKCCS to 1, system clock source will automatically switch to HSI clock when LSE is running and fail.

## 4.4.4 Clock verification and output

CW32W031 supports outputting various internal clock signals to external pins. Users can use this function to measure the current system's CPU operating frequency, system bus frequency, peripheral operating frequency, etc.

- HCLK\_OUT pin
   Output HCLK clock signal
- PCLK\_OUT pin
   Output PCLK clock signal
- HSE\_OUT pin
   Output HSE clock signal
- HSIOSC\_OUT pin
   Output HSIOSC clock signal
- LSE\_OUT pin
   Output LSE clock signal
- LSI\_OUT pinOutput LSI clock signal
- MCO\_OUT pin

Output HCLK/PCLK/HSIOSC/LSI/HSE/LSE/RC150K/RC10K clock signal, before the clock is output to the MCO\_OUT pin, it can be divided by a prescaler (effective frequency division factors are 1, 2, 8, 64, 128, 256, 512, 1024), so that the low-bandwidth instrument can accurately measure the signal.

The clock output block diagram is shown in the following figure:



Figure 4-5 Clock output

# 4.5 SysClk system clock switch

The system clock SysClk can select 4 clock sources, including HSE, LSE, HSI, and LSI. By setting the SYSCLK bit field of the system control register SYSCTRL\_CRO, it can be switched between different clock sources.

The main application scenarios include:

Automatic clock failover

When it is detected that the current system clock source fails, it can quickly and safely switch to other available clock sources to improve product reliability.

Power management

Switch the clock source of SysClk to low-speed clock in standby state to reduce system power consumption, and switch the clock source of SysClk to high-speed clock in normal use state to quickly respond to user needs.

The system clock switching operation must be performed in accordance with the five clock switching procedures described below, otherwise an exception may occur.

#### Caution:

When the system clock is switched, the FLASH control register FLASH\_CR2.WAIT needs to be configured synchronously to read the waiting period parameters: if the system clock frequency is not greater than 24MHz, the FLASH control register FLASH\_CR2.WAIT should be set to 0; if the system clock frequency is greater than 24MHz, the FLASH control register FLASH\_CR2.WAIT should be set is 1; if the system clock frequency is greater than 48MHz, the FLASH control register FLASH\_CR2. WAIT should be set to 2.



# 4.5.1 Standard Clock Switching Process

The standard clock switching operation flow is as follows:

- Step 1: If the new clock source is HSE or LSE, you need to configure the corresponding external pin to the appropriate mode: when connecting an external crystal, you need to configure it as an analog function, when connecting an external clock input, you need to set the GPIO as a digital input function and enable the port's input function;
- Step 2: Configure the oscillation parameters of the new clock source, such as drive capability, oscillation amplitude, stabilization period, etc.;
- Step 3: Set the new clock source oscillator enable bit to 1;
- Step 4: According to the higher frequency of the current clock source and the new clock source, configure the FLASH\_CR2.WAIT read wait period parameter according to the requirements of the chapter 7 FLASH Memory;
- Step 5: Wait for the new clock source to output a stable frequency (the STABLE signal of the new clock source becomes 1);
- Step 6: Configure the system control register SYSCTRL\_CR0.SYSCLK, and select the clock source of the system clock SysClk as the new clock source;
- Step 7: According to the frequency of the new clock source, configure the FLASH\_CR2.WAIT read waiting period parameter according to the requirements of the chapter 7 FLASH Memory;
- Step 8: Turn off clock sources that are no longer in use.

Taking the system clock switching from HSI to HSE as an example, the switching process of the old and new clocks is shown in the following figure:



Figure 4-6 HSI clock switched to HSE clock



62 / 572

Rev 1.0

## 4.5.2 HSI clock switching process between different frequencies

Switching between different frequencies of the HSI clock does not require starting a new clock source, but only needs to change the frequency division ratio of the HSI clock prescaler. The switching speed is fast, and there is no need to wait for the clock stabilization time before and after switching. The switching operation process is as follows:

- Step 1: According to the higher frequency of the current clock source and the new clock source, configure the FLASH\_CR2.WAIT read wait period parameter according to the requirements of the chapter 7 FLASH Memory;
- Step 2: Read the value of the built-in high-frequency clock control register SYSCTRL\_HSI register as Value;
- Step 3: According to the required target frequency, set the built-in high-frequency clock control register SYSCTRL\_HSI.DIV to the corresponding frequency division coefficient (note that the SYSCTRL\_HSI.TRIM field should remain unchanged);
- **Step 4:** According to the frequency of the new clock source, configure the FLASH\_CR2.WAIT read wait period parameter as required in the chapter *7 FLASH Memory*.

# 4.5.3 Example of switching from other clocks to LSE

The switching operation process is as follows:

- Step 1: Set PC14 / PC15 pins as analog function ports;
- Step 2: According to the characteristics of the external crystal of the LSE oscillator, configure the oscillation parameters of the new clock source LSE, such as drive capability (set by the external low-frequency crystal control register SYSCTRL\_LSE.DRIVER, it is recommended to configure 3), oscillation amplitude (by the external low-frequency crystal control register SYSCTRL\_LSE .AMP setting, it is recommended to configure 2 or 3), stable period (set through the external low-frequency crystal control register SYSCTRL\_LSE.WAITCYCLE, it is recommended to set to 3), etc.;
- **Step 3:** Set the system control register SYSCTRL\_CR1.LSEEN to 1 to enable the LSE crystal oscillator circuit; *Caution:*

The SYSCTRL\_CR1 register has the KEY protection feature. The upper 16-bit data of the written data must be 0x5A5A, otherwise it cannot be written.

- Step 4: Cyclic query and wait for the external low-frequency crystal control register SYSCTRL\_LSE.STABLE stable flag to become 1, that is, wait for the LSE crystal oscillator circuit to output a stable clock;
- **Step 5**: Set the system control register SYSCTRL\_CR0.SYSCLK to 4, and switch the SysClk clock source to LSE; *Caution:*

The SYSCTRL\_CR0 register has the KEY protection feature. The upper 16-bit data of the written data must be 0x5A5A, otherwise it cannot be written.

- **Step 6:** Configure the FLASH\_CR2.WAIT read wait period parameter according to the requirements of the chapter *7 FLASH Memory*;
- Step 7: Set the system control register SYSCTRL\_CR1.xxxEN to 0 to turn off the original clock.



# 4.5.4 Example of switching from other clocks to HSE

The switching operation process is as follows:

- Step 1: Set PF00/PF01 pins as analog function ports;
- Step 2: According to the characteristics of the external crystal of the HSE oscillator, configure the oscillation parameters of the new clock source HSE, such as crystal operating frequency (configured through the external high-frequency crystal control register SYSCTRL\_HSE.FREQRANGE), drive capability (through the external high-frequency crystal control register SYSCTRL\_HSE.DRIVER configuration), stabilization period (configured through the external high-frequency crystal control register SYSCTRL\_HSE. WAITCYCLE, it is recommended to set it to 3), etc.;
- **Step 3:** Set the system control register SYSCTRL\_CR1.HSEEN to 1 to enable the HSE crystal oscillator circuit; *Caution:*

The SYSCTRL\_CR1 register has the KEY protection feature. The upper 16-bit data of the written data must be 0x5A5A, otherwise it cannot be written.

- Step 4: According to the higher frequency of the current clock and HSE, configure the FLASH\_CR2.WAIT read waiting period parameter according to the requirements of the chapter 7 FLASH Memory;
- Step 5: Cyclic query in a loop and wait for the stable flag of the external high-frequency crystal control register SYSCTRL\_HSE.STABLE to become 1 to ensure that the crystal oscillator circuit outputs a stable clock;
- **Step 6:** Set the system control register SYSCTRL\_CR0.SYSCLK to 1, and switch the SysClk clock source to HSE; *Caution:*

The SYSCTRL\_CR0 register has the KEY protection feature. The upper 16-bit data of the written data must be 0x5A5A, otherwise it cannot be written.

- Step 7: According to the clock frequency of the HSE, configure the FLASH\_CR2.WAIT read waiting period parameter according to the requirements of the chapter 7 FLASH Memory;
- Step 8: Set the system control register SYSCTRL\_CR1.xxxEN to 0 to turn off the original clock.

# 4.5.5 Example of switching from other clocks to LSI

The switching operation process is as follows:

- Step 1: Configure the built-in low-frequency clock control register SYSCTRL\_LSI.TRIM and the built-in low-frequency clock control register SYSCTRL\_LSI.WAITCYCLE to appropriate values;
- Step 2: Set the system control register SYSCTRL\_CR1.LSIEN to 1 to enable the LSIRC oscillator circuit;

### Caution:

The SYSCTRL\_CR1 register has the KEY protection feature. The upper 16-bit data of the written data must be 0x5A5A, otherwise it cannot be written.

- Step 3: Cyclic query and wait for the built-in low-frequency clock control register SYSCTRL\_LSI.STABLE stable flag to become 1, that is, wait for the LSI to output a stable clock;
- **Step 4**: Set the system control register SYSCTRL\_CR0.SYSCLK to 3, and switch the SysClk clock source to LSI; *Caution:*

The SYSCTRL\_CR0 register has the KEY protection feature. The upper 16-bit data of the written data must be 0x5A5A, otherwise it cannot be written.

- Step 5: Configure the FLASH\_CR2.WAIT read wait period parameter to 0;
- Step 6: Set the system control register SYSCTRL\_CR1.xxxEN to 0 to turn off the original clock.



64 / 572 Rev 1.0

# 4.5.6 Example of switching from other clocks to HSI

The switching operation process is as follows:

- Step 1: Configure the built-in high-frequency clock control registers SYSCTRL\_HSI.TRIM, SYSCTRL\_HSI. WAITCYCLE and SYSCTRL\_HSI.DIV to appropriate values;
- **Step 2**: Set the system control register SYSCTRL\_CR1.HSIEN to 1 to enable the HSIOSC clock oscillation circuit; *Caution:*

The SYSCTRL\_CR1 register has the KEY protection feature. The upper 16-bit data of the written data must be 0x5A5A, otherwise it cannot be written.

- Step 3: Cyclic query and wait for the built-in high-frequency clock control register SYSCTRL\_HSI.STABLE stable flag to become 1, that is, wait for the HSIOSC to output a stable clock;
- Step 4: According to the higher frequency of the current clock and HSI, configure the FLASH\_CR2.WAIT read waiting period parameter according to the requirements of the chapter 7 FLASH Memory;
- **Step 5:** Set the system control register SYSCTRL\_CR0.SYSCLK to 0, and switch the SysClk clock source to HSI; *Caution:*

The SYSCTRL\_CR0 register has the KEY protection feature. The upper 16-bit data of the written data must be 0x5A5A, otherwise it cannot be written.

- Step 6: According to the clock frequency of HSI, configure the FLASH\_CR2.WAIT read waiting period parameter according to the requirements of the chapter *7 FLASH Memory*;
- Step 7: Set the system control register SYSCTRL\_CR1.xxxEN to 0 to turn off the original clock.

# 4.6 List of registers

SYSCTRL base address: SYSCTRL\_BASE = 0x4001 0000

Table 4-10 List of SYSCTRL registers

| Register name     | Register address    | Register description                                                |
|-------------------|---------------------|---------------------------------------------------------------------|
| SYSCTRL_CR0       | SYSCTRL_BASE + 0x00 | System Control Register 0                                           |
| SYSCTRL_CR1       | SYSCTRL_BASE + 0x04 | System Control Register 1                                           |
| SYSCTRL_CR2       | SYSCTRL_BASE + 0x08 | System Control Register 2                                           |
| SYSCTRL_IER       | SYSCTRL_BASE + 0x0C | System Interrupt Enable Control Register                            |
| SYSCTRL_ISR       | SYSCTRL_BASE + 0x10 | System Interrupt Flag Register                                      |
| SYSCTRL_ICR       | SYSCTRL_BASE + 0x14 | System Interrupt Flag Clear Register                                |
| SYSCTRL_HSI       | SYSCTRL_BASE + 0x18 | Internal high frequency clock control register                      |
| SYSCTRL_HSE       | SYSCTRL_BASE + 0x1C | External high frequency crystal control register                    |
| SYSCTRL_LSI       | SYSCTRL_BASE + 0x20 | Internal low frequency clock control register                       |
| SYSCTRL_LSE       | SYSCTRL_BASE + 0x24 | External low frequency crystal control register                     |
| SYSCTRL_DEBUG     | SYSCTRL_BASE + 0x2C | Debug Status Timer Control Register                                 |
| SYSCTRL_AHBEN     | SYSCTRL_BASE + 0x30 | AHB Peripheral Clock Enable Control Register                        |
| SYSCTRL_APBEN2    | SYSCTRL_BASE + 0x34 | APB Peripheral Clock Enable Control Register 2                      |
| SYSCTRL_APBEN1    | SYSCTRL_BASE + 0x38 | APB Peripheral Clock Enable Control Register 1                      |
| SYSCTRL_AHBRST    | SYSCTRL_BASE + 0x40 | AHB Peripheral Reset Control Register                               |
| SYSCTRL_APBRST2   | SYSCTRL_BASE + 0x44 | APB Peripheral Reset Control Register 2                             |
| SYSCTRL_APBRST1   | SYSCTRL_BASE + 0x48 | APB Peripheral Reset Control Register 1                             |
| SYSCTRL_RESETFLAG | SYSCTRL_BASE + 0x4C | System Reset Flag Register                                          |
| SYSCTRL_GTIM1CAP  | SYSCTRL_BASE + 0x50 | General-Purpose Timer 1 Input Capture Source Configuration Register |
| SYSCTRL_GTIM2CAP  | SYSCTRL_BASE + 0x54 | General-Purpose Timer 2 Input Capture Source Configuration Register |
| SYSCTRL_ATIMETR   | SYSCTRL_BASE + 0x60 | Advanced Timer ETR Source Configuration Register                    |
| SYSCTRL_GTIMETR   | SYSCTRL_BASE + 0x64 | General Purpose Timer ETR Source Configuration Register             |
| SYSCTRL_TIMITR    | SYSCTRL_BASE + 0x6C | Timer ITR Source Configuration Register                             |
| SYSCTRL_MCO       | SYSCTRL_BASE + 0x70 | System Clock Output Control Register                                |

# 4.7 Register description

See section 1 Documentation conventions for abbreviations used in register descriptions.

# 4.7.1 SYSCTRL\_CR0 System Control Register 0

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name    | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|---------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | KEY     | WO         | Only when KEY is 0x5A5A, the write operation of this register is valid                                                                                                                                                                                                                                                                                                                                                                      |
| 15:8      | RFU     | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                |
| 7:5       | HCLKPRS | RW         | Configure the clock source of HCLK  000: Set the clock source of HCLK to SysClk  001: Set the clock source of HCLK to SysClk / 2  010: Set the clock source of HCLK to SysClk / 4  011: Set the clock source of HCLK to SysClk / 8  100: Set the clock source of HCLK to SysClk / 16  101: Set the clock source of HCLK to SysClk / 32  110: Set the clock source of HCLK to SysClk / 64  111: Set the clock source of HCLK to SysClk / 128 |
| 4:3       | PCLKPRS | RW         | Configure the clock source of PCLK  00: Set the clock source of PCLK to HCLK  01: Set the clock source of PCLK to HCLK / 2  10: Set the clock source of PCLK to HCLK / 4  11: Set the clock source of PCLK to HCLK / 8                                                                                                                                                                                                                      |
| 2:0       | SYSCLK  | RW         | Configure the clock source of SysClk 000: Set the clock source of SysClk to HSI 001: Set the clock source of SysClk to HSE 011: Set the clock source of SysClk to LSI 100: Set the clock source of SysClk to LSE                                                                                                                                                                                                                            |

# 4.7.2 SYSCTRL\_CR1 System Control Register 1

Address offset: 0x04 Reset value: 0x0000 0001

| Bit field | Name    | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------|---------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | KEY     | WO         | Only when KEY is 0x5A5A, the write operation of this register is valid                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15:9      | RFU     | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8         | CLKCCS  | RW         | Configure the crystal oscillator for safe operation in the event of a failure in operation  0: No action  1: Automatically switch the clock source of SysClk to HSI                                                                                                                                                                                                                                                                                                                     |
| 7         | HSECCS  | RW         | High Frequency Crystal Oscillator Clock Detector Enable Configuration 0: Disable HSE Clock Detector 1: Enable HSE Clock Detector Caution 1: During operation, if the number of clocks output by the HSE within the duration of each HSE. DETCNT LSI clock is less than 0x20000, it is determined that the HSE is invalid during operation. Caution 2: During startup, if the conditions specified by HSE.WAITCYCLE are not met, it is determined that the HSE startup fails.            |
| 6         | LSECCS  | RW         | Low Frequency Crystal Oscillator Clock Monitor Enable Configuration 0: Disable LSE Clock Monitor 1: Enable LSE Clock Monitor Caution 1: During operation, if the number of clocks output by the LSE is less than 128 within the duration of every 256 LSI clocks (about 7.8ms), it is determined that the LSE fails during operation. Caution 2: During startup, if the conditions specified by LSE.WAITCYCLE are not met, it is determined that the LSE has failed to start vibrating. |
| 5         | LSELOCK | RW         | External low-speed clock LSE lock control 0: LSEEN can be set and cleared 1: LSEEN only settable                                                                                                                                                                                                                                                                                                                                                                                        |
| 4         | LSEEN   | RW         | External low-speed clock LSE enable control 0: Disable 1: Enable Caution 1: When the system enters DeepSleep, this low-speed clock will not automatically shut down. Caution 2: Only a power-on reset can reset this control bit.                                                                                                                                                                                                                                                       |

| Bit field | Name  | Permission | Function description                                                                                                                                                    |
|-----------|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3         | LSIEN | RW         | Internal low-speed clock LSI enable control 0: Disable 1: Enable Caution: When the system enters DeepSleep, this low-speed clock will not automatically shut down.      |
| 2         | RFU   | -          | Reserved bits, please keep the default value                                                                                                                            |
| 1         | HSEEN | RW         | External high-speed clock HSE enable control 0: Disable 1: Enable Caution: When the system enters DeepSleep, this high-speed clock will be automatically turned off.    |
| 0         | HSIEN | RW         | Internal high-speed clock HSIOSC enable control 0: Disable 1: Enable Caution: When the system enters DeepSleep, this high-speed clock will be automatically turned off. |

# 4.7.3 SYSCTRL\_CR2 SYSCTRL\_CR2 System Control Register 2

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name      | Permission | Function description                                                                                                                                                                                                                                                                                     |
|-----------|-----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | KEY       | WO         | Only when KEY is 0x5A5A, the write operation of this register is valid                                                                                                                                                                                                                                   |
| 15:7      | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                             |
| 6:4       | FLASHWAIT | RW         | FLASH instruction fetches cycle configuration 000: 1 HCLK cycle for HCLK<=24MHz 001: 2 HCLK cycle for 24MHz <hclk<=48mhz 010:="" 3="" 48mhz<hclk<="72MHz" as="" bit="" caution:="" control="" cycle="" flash_cr2[2:0].<="" for="" function="" has="" hclk="" same="" td="" the="" this=""></hclk<=48mhz> |
| 3         | WAKEUPCLK | RW         | When DeepSleep wakes up, the source configuration of the system clock  0: Keep the original system clock source  1: Switch the system clock source to HSI 8MHz, keep the original system clock source enabled                                                                                            |
| 2         | LOCKUP    | RW         | Cortex-M0+ LockUp Functional configuration 0: Disable 1: Enable Caution: When this function is enabled, the CPU will reset the MCU when it reads an invalid instruction.                                                                                                                                 |
| 1         | SWDIO     | RW         | SWD Port function configuration 0: PA14, PA13 are used as SWD ports, GPIO function is not available 1: PA14, PA13 are used as GPIO ports, SWD function is not available                                                                                                                                  |
| 0         | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                             |

# 4.7.4 SYSCTRL\_HSI Internal high frequency clock control register

Address offset: 0x18 Reset value: 0x----

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15        | STABLE | RO         | HSIOSC Clock Stable Status Bits 0: HSIOSC clock has not stabilized 1: HSIOSC clock has stabilized                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14:11     | DIV    | RW         | HSI clock and HSIOSC clock division factor configuration 0101: HSI = HSIOSC / 6 (Default) 0110: HSI = HSIOSC / 1 1000: HSI = HSIOSC / 2 1001: HSI = HSIOSC / 4 1011: HSI = HSIOSC / 8 1100: HSI = HSIOSC / 10 1101: HSI = HSIOSC / 12 1110: HSI = HSIOSC / 14 1111: HSI = HSIOSC / 16                                                                                                                                                                                                                                              |
| 10:0      | TRIM   | RW         | Clock frequency adjustment, changing the value of this register bit can adjust the oscillation frequency of the HSIOSC. Every time the TRIM value increases by 1, the oscillation frequency of the HSIOSC increases by about 0.2%, and the total adjustment range is 32 ~ 48MHz. The calibration value of 48MHz has been saved in FLASH, and the accurate frequency can be obtained by reading the calibration value in FLASH and writing it into SYSCTRL_HSI.TRIM.  48.00M Calibration value address: : 0x0010 0A00 – 0x0010 0A01 |

# 4.7.5 SYSCTRL\_LSI Internal low frequency clock control register

Address offset: 0x20 Reset value: 0x----

| Bit field | Name      | Permission | Function description                                                                                                                                                                                                                                                   |
|-----------|-----------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                           |
| 15        | STABLE    | RO         | LSI Clock Stable Status Bit<br>0: LSI clock has not stabilized<br>1: LSI clock has stabilized                                                                                                                                                                          |
| 14:12     | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                           |
| 11:10     | WAITCYCLE | RW         | Internal low-speed clock LSI stabilization time selection 00: 6 cycles 01: 18 cycles 10: 66 cycles 11: 258 cycles                                                                                                                                                      |
| 9:0       | TRIM      | RW         | Internal low-speed clock frequency adjustment, 1 set of frequency calibration values are saved in FLASH.  Read the calibration value in FLASH and write it to SYSCTRL_LSI.TRIM to get the exact frequency.  32.8K Calibration value address: 0x0010 0A02 - 0x0010 0A03 |

# 4.7.6 SYSCTRL\_HSE External high frequency crystal control register

Address offset: 0x1C Reset value: 0x0007 FF22

| Bit field | Name      | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------|-----------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20     | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                            |
| 19        | STABLE    | RO         | HSE Clock Stable Status Bits 0: HSE clock has not stabilized 1: HSE clock has stabilized                                                                                                                                                                                                                                                                                                                                                                |
| 18:8      | DETCNT    | RW         | HSE operation failure detection cycle configuration Considering the clock error, the value of DETCNT should generally be set to $8000 / f_{\rm HSE}$ Example: HSE is 4MHz, then DETCNT should be configured as 2000 Caution: DETCNT must be greater than 0.                                                                                                                                                                                             |
| 7         | FLT       | RW         | External high-speed clock HSE filter control 0: Disable HSE filtering 1: Enable HSE filter function, HSE frequency should not be greater than 8MHz Caution: Filters should only be used in high-interference scenarios.                                                                                                                                                                                                                                 |
| 6         | MODE      | RW         | External high-speed clock HSE working mode configuration 0: HSE works in crystal mode, and its output clock is generated by crystal and internal circuit oscillation 1: HSE works in input mode, and its output clock comes from OSC_IN pin                                                                                                                                                                                                             |
| 5:4       | WAITCYCLE | RW         | Selection of the number of clock cycles for HSE stability detection and start-up failure detection 00: Waiting for 8192 HSE clock signals 01: Waiting for 32768 HSE clock signals 10: Waiting for 131072 HSE clock signals 11: Waiting for 262144 HSE clock signals Caution: When HSECCS is enabled, the start-up failure detection circuit will detect the number of HSE clock signals within a limited time, which is 65ms, 65ms, 130ms respectively. |
| 3:2       | FREQRANGE | RW         | External crystal operating frequency selection 00: 4M~8M 01: 8M~16M 10: 16M~24M 11: 24M~32M                                                                                                                                                                                                                                                                                                                                                             |

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0       | DRIVER | RW         | HSE crystal drive capability selection 00: Weakest drive capability 01: Weak drive ability 10: Default drive capability (recommended value) 11: The strongest driving ability Caution: The appropriate drive capability needs to be selected based on the crystal characteristics, load capacitance, and board parasitics. The stronger the driving ability, the greater the power consumption, and the weaker the driving ability, the smaller the power consumption. |

### 4.7.7 SYSCTRL\_LSE External low frequency crystal control register

Address offset: 0x24 Reset value: 0x0000 002B

| Bit field | Name      | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|-----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15        | STABLE    | RO         | LSE Clock Stable Status Bit 0: LSE clock has not stabilized 1: LSEclock has stabilized                                                                                                                                                                                                                                                                                                                                                                               |
| 14:7      | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6         | MODE      | RW         | External low-speed clock LSE working mode configuration 0: LSE works in crystal mode, and its output clock is generated by crystal and internal circuit oscillation 1: LSE works in input mode, and its output clock comes from OSC32_IN pin                                                                                                                                                                                                                         |
| 5:4       | WAITCYCLE | RW         | Selection of the number of clock cycles for LSE stability detection and start-up failure detection 00: Waiting for 256 LSE clock signals 0: Waiting for 1024 LSE clock signals 10: Waiting for 4096 LSE clock signals 11: Waiting for 16384 LSE clock signals Caution: When LSECCS is enabled, the start-up failure detection circuit will detect the number of LSE clock signals within a limited time. The four-stage limited time is 1s, 1s, and 2s respectively. |
| 3:2       | AMP       | RW         | LSE crystal oscillation amplitude configuration 00: Minimum amplitude 01: Small amplitude 10: Normal amplitude (recommended value) 11: Larger amplitude                                                                                                                                                                                                                                                                                                              |
| 1:0       | DRIVER    | RW         | LSE crystal drive capability configuration 00: Minimum drive capacity 01: Less drive capacity 10: Normal drive capability 11: Strong driving ability (recommended value) Caution: The appropriate drive capability needs to be selected based on the crystal characteristics, load capacitance, and board parasitics. The stronger the driving ability, the greater the power consumption, and the weaker the driving ability, the smaller the power consumption.    |

#### Caution:

Only a power-on reset can reset this register.



### 4.7.8 SYSCTRL\_IER System Interrupt Enable Control Register

Address offset: 0x0C Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                                                       |
|-----------|----------|------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:16     | KEY      | WO         | Only when KEY is 0x5A5A, the write operation of this register is valid                                                     |
| 15:9      | RFU      | -          | Reserved bits, please keep the default value                                                                               |
| 8         | HSEFAULT | RW         | HSE Fail-Run Interrupt Enable Control 0: Disable HSE run-fail interrupt 1: Enable HSE run-fail interrupt                   |
| 7         | LSEFAULT | RW         | LSE Fail-Run Interrupt Enable Control 0: Disable LSE run-fail interrupt 1: Enable LSE run-fail interrupt                   |
| 6         | HSEFAIL  | RW         | HSE Start-up failure interrupt enable control 0: Disable HSE start failure interrupt 1: Enable HSE start failure interrupt |
| 5         | LSEFAIL  | RW         | LSE Start-up failure interrupt enable control 0: Disable LSE start failure interrupt 1: Enable LSE start failure interrupt |
| 4         | LSERDY   | RW         | LSE Stable Interrupt Enable Control 0: Disable LSE stable interrupt 1: Enable LSE stable interrupt                         |
| 3         | LSIRDY   | RW         | LSI Stable Interrupt Enable Control 0: Disable LSI stable interrupt 1: Enable LSI stable interrupt                         |
| 2         | RFU      | -          | Reserved bits, please keep the default value                                                                               |
| 1         | HSERDY   | RW         | HSE Stable Interrupt Enable Control 0: Disable HSE stable interrupt 1: Enable HSE stable interrupt                         |
| 0         | HSIRDY   | RW         | HSIOSC Stable Interrupt Enable Control 0: Disable HSIOSC stable interrupt 1: Enable HSIOSC stable interrupt                |

#### Caution 1:

The FAULT interrupt (vector number 47) is executed when the HSEFAULT interrupt or LSEFAULT interrupt is generated, and the RCC global interrupt (vector number 20) is executed when the other interrupt is generated.



# 4.7.9 SYSCTRL\_ISR System Interrupt Flag Register

Address offset: 0x10 Reset value: 0x0000 0801

| Bit field | Name      | Permission | Function description                                                                                                    |
|-----------|-----------|------------|-------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU       | -          | Reserved bits, please keep the default value                                                                            |
| 15        | LSESTABLE | RO         | LSE clock stable status bit; hardware set to clear 0: LSE clock has not stabilized 1: LSE clock has stabilized          |
| 14        | LSISTABLE | RO         | LSI clock stable status bit; hardware set to clear 0: LSI clock has not stabilized 1: LSI clock has stabilized          |
| 13        | RFU       | -          | Reserved bits, please keep the default value                                                                            |
| 12        | HSESTABLE | RO         | HSE clock stable status bit; hardware set to clear 0: HSE clock has not stabilized 1: HSE clock has stabilized          |
| 11        | HSISTABLE | RO         | HSIOSC clock stable status bit; hardware set to clear 0: HSIOSC clock has not stabilized 1: HSIOSC clock has stabilized |
| 10:9      | RFU       | -          | Reserved bits, please keep the default value                                                                            |
| 8         | HSEFAULT  | RO         | HSE Clock run failure flag 0: HSE clock is running fine 1: Oscillation stopped during HSE clock operation               |
| 7         | LSEFAULT  | RO         | LSE Clock run failure flag 0: LSE clock is running fine 1: Oscillation stopped during LSE clock operation               |
| 6         | HSEFAIL   | RO         | HSE Clock start-up failure flag<br>0: HSE Clock starts up successfully<br>1: HSE clock start-up failed                  |
| 5         | LSEFAIL   | RO         | LSE Clock start-up failure flag 0: LSE Clock starts up successfully 1: LSE clock start-up failed                        |
| 4         | LSERDY    | RO         | LSE Clock Stable Flag 0: LSE clock has not stabilized 1: LSE clock has stabilized                                       |
| 3         | LSIRDY    | RO         | LSI Clock Stable Flag<br>0: LSI clock has not stabilized<br>1: LSI clock has stabilized                                 |
| 2         | RFU       | -          | Reserved bits, please keep the default value                                                                            |
| 1         | HSERDY    | RO         | HSE Clock Stable Flag<br>0: HSE clock has not stabilized<br>1: HSE clock has stabilized                                 |

| Bit field | Name   | Permission | Function description                                                                             |
|-----------|--------|------------|--------------------------------------------------------------------------------------------------|
| 0         | HSIRDY | RO         | HSIOSC Clock Stable Flag<br>0: HSIOSC clock has not stabilized<br>1: HSIOSC clock has stabilized |

# 4.7.10 SYSCTRL\_ICR System Interrupt Flag Clear Register

Address offset: 0x14 Reset value: 0x0000 01FF

| Bit field | Name     | Permission | Function description                                                                                                      |
|-----------|----------|------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:9      | RFU      | -          | Reserved bits, please keep the default value                                                                              |
| 8         | HSEFAULT | R1W0       | HSE Clock operation failure flag clear control<br>W0: Clear the corresponding flag in the ISR register<br>W1: No function |
| 7         | LSEFAULT | R1W0       | LSE Clock operation failure flag clear control<br>W0: Clear the corresponding flag in the ISR register<br>W1: No function |
| 6         | HSEFAIL  | R1W0       | HSE Clock start-up failure flag clear control<br>W0: Clear the corresponding flag in the ISR register<br>W1: No function  |
| 5         | LSEFAIL  | R1W0       | LSE Clock start-up failure flag clear control<br>W0: Clear the corresponding flag in the ISR register<br>W1: No function  |
| 4         | LSERDY   | R1W0       | LSE Clock stable flag clear control<br>W0: Clear the corresponding flag in the ISR register<br>W1: No function            |
| 3         | LSIRDY   | R1W0       | LSI Clock stable flag clear control<br>W0: Clear the corresponding flag in the ISR register<br>W1: No function            |
| 2         | RFU      | -          | Reserved bits, please keep the default value                                                                              |
| 1         | HSERDY   | R1W0       | HSE Clock stable flag clear control<br>W0: Clear the corresponding flag in the ISR register<br>W1: No function            |
| 0         | HSIRDY   | R1W0       | HSIOSC Clock stable flag clear control<br>W0: Clear the corresponding flag in the ISR register<br>W1: No function         |

# 4.7.11 SYSCTRL\_AHBEN AHB Peripheral Clock Enable Control Register

Address offset: 0x30 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                                 |
|-----------|-------|------------|--------------------------------------------------------------------------------------|
| 31:10     | RFU   | -          | Reserved bits, please keep the default value                                         |
| 9         | GPIOF | RW         | GPIOF Port configuration clock and working clock enable control 0: Disable 1: Enable |
| 8:7       | RFU   | -          | Reserved bits, please keep the default value                                         |
| 6         | GPIOC | RW         | GPIOC Port configuration clock and working clock enable control 0: Disable 1: Enable |
| 5         | GPIOB | RW         | GPIOB Port configuration clock and working clock enable control 0: Disable 1: Enable |
| 4         | GPIOA | RW         | GPIOA Port configuration clock and working clock enable control 0: Disable 1: Enable |
| 3         | RFU   | -          | Reserved bits, please keep the default value                                         |
| 2         | CRC   | RW         | CRC Module configuration clock and working clock enable control 0: Disable 1: Enable |
| 1         | FLASH | RW         | FLASH Module configuration clock enable control 0: Disable 1: Enable                 |
| 0         | DMA   | RW         | DMA Module configuration clock and working clock enable control 0: Disable 1: Enable |

# 4.7.12 SYSCTRL\_APBEN1 APB Peripheral Clock Enable Control Register 1

Address offset: 0x38 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                                   |
|-----------|-------|------------|----------------------------------------------------------------------------------------|
| 31:12     | RFU   | -          | Reserved bits, please keep the default value                                           |
| 11        | I2C   | RW         | I2C Module configuration clock and working clock enable control 0: Disable 1: Enable   |
| 10:9      | RFU   | -          | Reserved bits, please keep the default value                                           |
| 8         | UART3 | RW         | UART3 Module configuration clock enable control 0: Disable 1: Enable                   |
| 7         | UART2 | RW         | UART2 Module configuration clock enable control 0: Disable 1: Enable                   |
| 6         | RFU   | -          | Reserved bits, please keep the default value                                           |
| 5         | IWDT  | RW         | IWDT Module configuration clock enable control 0: Disable 1: Enable                    |
| 4         | WWDT  | RW         | WWDT Module configuration clock and working clock enable control 0: Disable 1: Enable  |
| 3         | RTC   | RW         | RTC Module configuration clock enable control 0: Disable 1: Enable                     |
| 2         | GTIM2 | RW         | GTIM2 Module configuration clock and working clock enable control 0: Disable 1: Enable |
| 1         | GTIM1 | RW         | GTIM1 Module configuration clock and working clock enable control 0: Disable 1: Enable |
| 0         | RFU   | -          | Reserved bits, please keep the default value                                           |

# 4.7.13 SYSCTRL\_APBEN2 APB Peripheral Clock Enable Control Register 2

Address offset: 0x34 Reset value: 0x0000 8000

| Bit field | Name  | Permission | Function description                                                                     |
|-----------|-------|------------|------------------------------------------------------------------------------------------|
| 31:14     | RFU   | -          | Reserved bits, please keep the default value                                             |
| 13        | AWT   | RW         | AWT Module configuration clock enable control 0: Disable 1: Enable                       |
| 12        | BTIM  | RW         | BTIM1-3 Module configuration clock and working clock enable control 0: Disable 1: Enable |
| 11:10     | RFU   | -          | Reserved bits, please keep the default value                                             |
| 9         | UART1 | RW         | UART1 Module configuration clock enable control 0: Disable 1: Enable                     |
| 8         | SPI   | RW         | SPI Module configuration clock and working clock enable control 0: Disable 1: Enable     |
| 7         | ATIM  | RW         | ATIM Module configuration clock and working clock enable control 0: Disable 1: Enable    |
| 6:5       | RFU   | -          | Reserved bits, please keep the default value                                             |
| 4         | VC    | RW         | VC Module configuration clock enable control 0: Disable 1: Enable                        |
| 3         | RFU   | RW         | Reserved bits, please keep the default value                                             |
| 2         | ADC   | RW         | ADC Module configuration clock and working clock enable control 0: Disable 1: Enable     |
| 1:0       | RFU   |            | Reserved bits, please keep the default value                                             |

### 4.7.14 SYSCTRL\_AHBRST AHB Peripheral Reset Control Register

Address offset: 0x40 Reset value: 0x0000 0277

| Bit field | Name  | Permission | Function description                                                        |
|-----------|-------|------------|-----------------------------------------------------------------------------|
| 31:10     | RFU   | -          | Reserved bits, please keep the default value                                |
| 9         | GPIOF | RW         | GPIOF Module reset control 0: Module is in reset state 1: Module works fine |
| 8:7       | RFU   | -          | Reserved bits, please keep the default value                                |
| 6         | GPIOC | RW         | GPIOC Module reset control 0: Module is in reset state 1: Module works fine |
| 5         | GPIOB | RW         | GPIOB Module reset control 0: Module is in reset state 1: Module works fine |
| 4         | GPIOA | RW         | GPIOA Module reset control 0: Module is in reset state 1: Module works fine |
| 3         | RFU   | -          | Reserved bits, please keep the default value                                |
| 2         | CRC   | RW         | CRC Module reset control 0: Module is in reset state 1: Module works fine   |
| 1         | FLASH | RW         | FLASH Module reset control 0: Module is in reset state 1: Module works fine |
| 0         | DMA   | RW         | DMA Module reset control 0: Module is in reset state 1: Module works fine   |

# 4.7.15 SYSCTRL\_APBRST1 APB Peripheral Reset Control Register 1

Address offset: 0x48 Reset value: 0x0000 09BF

| Bit field | Name  | Permission | Function description                                                        |
|-----------|-------|------------|-----------------------------------------------------------------------------|
| 31:12     | RFU   | -          | Reserved bits, please keep the default value                                |
| 11        | I2C   | RW         | I2C Module reset control 0: Module is in reset state 1: Module works fine   |
| 10:9      | RFU   | -          | Reserved bits, please keep the default value                                |
| 8         | UART3 | RW         | UART3 Module reset control 0: Module is in reset state 1: Module works fine |
| 7         | UART2 | RW         | UART2 Module reset control 0: Module is in reset state 1: Module works fine |
| 6         | RFU   | -          | Reserved bits, please keep the default value                                |
| 5         | IWDT  | RW         | IWDT Module reset control 0: Module is in reset state 1: Module works fine  |
| 4         | WWDT  | RW         | WWDT Module reset control 0: Module is in reset state 1: Module works fine  |
| 3         | RTC   | RW         | RTC Module reset control 0: Module is in reset state 1: Module works fine   |
| 2         | GTIM2 | RW         | GTIM2 Module reset control 0: Module is in reset state 1: Module works fine |
| 1         | GTIM1 | RW         | GTIM1 Module reset control 0: Module is in reset state 1: Module works fine |
| 0         | RFU   | -          | Reserved bits, please keep the default value                                |

### 4.7.16 SYSCTRL\_APBRST2 APB Peripheral Reset Control Register 2

Address offset: 0x44 Reset value: 0x0000 339D

| Bit field | Name  | Permission | Function description                                                          |
|-----------|-------|------------|-------------------------------------------------------------------------------|
| 31:14     | RFU   | -          | Reserved bits, please keep the default value                                  |
| 13        | AWT   | RW         | AWT Module reset control 0: Module is in reset state 1: Module works fine     |
| 12        | ВТІМ  | RW         | BTIM1-3 Module reset control 0: Module is in reset state 1: Module works fine |
| 11:10     | RFU   | -          | Reserved bits, please keep the default value                                  |
| 9         | UART1 | RW         | UART1 Module reset control 0: Module is in reset state 1: Module works fine   |
| 8         | SPI   | RW         | SPI Module reset control 0: Module is in reset state 1: Module works fine     |
| 7         | ATIM  | RW         | ATIM Module reset control 0: Module is in reset state 1: Module works fine    |
| 6:5       | RFU   | -          | Reserved bits, please keep the default value                                  |
| 4         | VC    | RW         | VC Module reset control 0: Module is in reset state 1: Module works fine      |
| 3         | RFU   | -          | Reserved bits, please keep the default value                                  |
| 2         | ADC   | RW         | ADC Module reset control 0: Module is in reset state 1: Module works fine     |
| 1:0       | RFU   | -          | Reserved bits, please keep the default value                                  |

# 4.7.17 SYSCTRL\_RESETFLAG System Reset Flag Register

Address offset: 0x4C Reset value: 0x----

| Bit field | Name        | Permission | Function description                                                                                                                                                 |
|-----------|-------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10     | RFU         | -          | Reserved bits, please keep the default value                                                                                                                         |
| 9         | SYSRESETREQ | RW0        | Cortex-M0+ CPU SYSRESETREQ soft reset flag 0: No CPU SYSRESETREQ soft reset occurred 1: CPU SYSRESETREQ soft reset has occurred Write 0 to clear, write 1 to invalid |
| 8         | LOCKUP      | RW0        | Cortex-M0+ CPU Lockup reset flag 0: No Lockup reset occurred 1: Lockup reset has occurred Write 0 to clear, write 1 to invalid                                       |
| 7         | RFU         | -          | Reserved bits, please keep the default value                                                                                                                         |
| 6         | RSTB        | RW0        | NRST pin reset flag 0: No Pin reset occurred 1: Pin reset has occurred Write 0 to clear, write 1 to invalid                                                          |
| 5         | WWDT        | RW0        | WWDT reset flag, requires software initialization and clearing 0: No WWDT reset occurred 1: WWDT reset has occurred Write 0 to clear, write 1 to invalid             |
| 4         | IWDT        | RW0        | IWDT reset flag 0: No IWDT reset occurred 1: IWDT reset has occurred Write 0 to clear, write 1 to invalid                                                            |
| 3         | LVD         | RW0        | LVD reset flag 0: No LVD reset occurred 1: LVD reset has occurred Write 0 to clear, write 1 to invalid                                                               |
| 2:1       | RFU         | -          | Reserved bits, please keep the default value                                                                                                                         |
| 0         | POR         | RW0        | POR/BOR reset flag 0: No POR/BOR reset occurred 1: POR/BOR reset has occurred Write 0 to clear, write 1 to invalid                                                   |

# 4.7.18 SYSCTRL\_DEBUG Debug Status Timer Control Register

Address offset: 0x2C Reset value: 0x0000 07E7

| Bit field | Name    | Permission | Function description                                                                                      |
|-----------|---------|------------|-----------------------------------------------------------------------------------------------------------|
| 31:11     | RFU     | -          | Reserved bits, please keep the default value                                                              |
| 10        | WWDT    | RW         | In the debugging state, WWDT count function configuration 0: Normal count 1: Pause count                  |
| 9         | IWDT    | RW         | In the debugging state, IWDT count function configuration 0: Normal count 1: Pause count                  |
| 8         | RTC     | RW         | In the debugging state, RTC count function configuration 0: Normal count 1: Pause count                   |
| 7         | RFU     | -          | Reserved bits, please keep the default value                                                              |
| 6         | AWT     | RW         | In the debugging state, AWT count function configuration 0: Normal count 1: Pause count                   |
| 5         | BTIM123 | RW         | In the debugging state, BTIM1 / BTIM2 / BTIM3 count function configuration 0: Normal count 1: Pause count |
| 4:3       | RFU     | -          | Reserved bits, please keep the default value                                                              |
| 2         | GTIM2   | RW         | In the debugging state, GTIM2 count function configuration 0: Normal count 1: Pause count                 |
| 1         | GTIM1   | RW         | In the debugging state, GTIM1 count function configuration 0: Normal count 1: Pause count                 |
| 0         | ATIM    | RW         | In the debugging state, ATIM count function configuration 0: Normal count 1: Pause count                  |

### 4.7.19 SYSCTRL\_GTIM1CAP General-Purpose Timer 1 Input Capture Source Configuration Register

Address offset: 0x50 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                        |
|-----------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                |
| 14:12     | CH4  | RW         | CH4 input capture source configuration of GTIM1 See GTIM1CAP [2:0] for details                                                                                                                                                                                              |
| 11        | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                |
| 10:8      | CH3  | RW         | CH3 input capture source configuration of GTIM1 See GTIM1CAP [2:0] for details                                                                                                                                                                                              |
| 7         | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                |
| 6:4       | CH2  | RW         | CH2 input capture source configuration of GTIM1 See GTIM1CAP [2:0] for details                                                                                                                                                                                              |
| 3         | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                |
| 2:0       | CH1  | RW         | CH1 input capture source configuration of GTIM1 000: Configured by GPIOx_AFRH and GPIOx_AFRL 001: RXD signal of UART1 010: RXD signal of UART2 011: RXD signal of UART3 100: Comparison output signal of VC1 101: Comparison output signal of VC2 110: Output signal of LVD |

### 4.7.20 SYSCTRL\_GTIM2CAP General-Purpose Timer 2 Input Capture Source Configuration Register

Address offset: 0x54 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                        |
|-----------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                |
| 14:12     | CH4  | RW         | CH4 input capture source configuration of GTIM2 See GTIM2CAP [2:0]                                                                                                                                                                                                          |
| 11        | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                |
| 10:8      | CH3  | RW         | CH3 input capture source configuration of GTIM2 See GTIM2CAP [2:0]                                                                                                                                                                                                          |
| 7         | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                |
| 6:4       | CH2  | RW         | CH2 input capture source configuration of GTIM2 See GTIM2CAP [2:0] for details                                                                                                                                                                                              |
| 3         | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                |
| 2:0       | CH1  | RW         | CH1 input capture source configuration of GTIM1 000: Configured by GPIOx_AFRH and GPIOx_AFRL 001: RXD signal of UART1 010: RXD signal of UART2 011: RXD signal of UART3 100: Comparison output signal of VC1 101: Comparison output signal of VC2 110: Output signal of LVD |

### 4.7.21 SYSCTRL\_ATIMETR Advanced Timer ETR Source Configuration

Address offset: 0x60 Reset value: 0x0000 0000

| Bit field | Name    | Permission | Function description                                                                                                                                                                                                                                             |
|-----------|---------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3      | RFU     | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                     |
| 2:0       | ATIMETR | RW         | ETR Source Configuration of ATIM  000: Configured by GPIOx_AFRH and GPIOx_AFRL  001: RXD signal of UART1  010: RXD signal of UART2  011: RXD signal of UART3  100: Comparison output signal of VC1  101: Comparison output signal of VC2  110: LVD output signal |

# 4.7.22 SYSCTRL\_GTIMETR General Purpose Timer ETR Source Configuration Register

Address offset: 0x64 Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                                                                                                                                                                                       |
|-----------|----------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7      | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                               |
| 6:4       | GTIM2ETR | RW         | ETR source configuration for GTIM2 See GTIMETR [2:0]                                                                                                                                                                                                       |
| 3         | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                               |
| 2:0       | GTIM1ETR | RW         | ETR Source Configuration of GTIM1 000: Configured by GPIOx_AFRH and GPIOx_AFRL 001: RXD signal of UART1 010: RXD signal of UART2 011: RXD signal of UART3 100: Comparison output signal of VC1 101: Comparison output signal of VC2 110: LVD output signal |

# 4.7.23 SYSCTRL\_TIMITR Timer ITR Source Configuration Register

Address offset: 0x6C Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                                                                                                                                                                               |
|-----------|----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24     | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                       |
| 23:21     | BTIM3ITR | RW         | ITR source configuration for BTIM3 See TIMITR [2:0]                                                                                                                                                                                                |
| 20:18     | BTIM2ITR | RW         | ITR source configuration for BTIM2 See TIMITR [2:0]                                                                                                                                                                                                |
| 17:15     | BTIM1ITR | RW         | ITR source configuration for BTIM1 See TIMITR [2:0]                                                                                                                                                                                                |
| 14:9      | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                       |
| 8:6       | GTIM2ITR | RW         | ITR source configuration for GTIM2 See TIMITR [2:0]                                                                                                                                                                                                |
| 5:3       | GTIM1ITR | RW         | ITR source configuration for GTIM1 See TIMITR [2:0]                                                                                                                                                                                                |
| 2:0       | ATIMITR  | RW         | ITR source configuration for ATIM 000: The overflow signal of BTIM1 001: The overflow signal of BTIM2 010: The overflow signal of BTIM3 011: The overflow signal of GTIM1 100: The overflow signal of GTIM2 111: Master mode output signal of ATIM |

#### Caution:

The ITR source of the TIM cannot be configured as its own overflow signal.

# 4.7.24 SYSCTRL\_MCO System Clock Output Control Register

Address offset: 0x70 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                            |
|-----------|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7      | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                    |
| 6:4       | DIV    | RW         | MCO output frequency division control 000: 1 Frequency Division 001: 2 Frequency Division 010: 8 Frequency Division 011: 64 Frequency Division 100: 128 Frequency Division 101: 256 Frequency Division 111: 512 Frequency Division 111: 1024 Frequency Division |
| 3:0       | SOURCE | RW         | MCO output signal source configuration 0000: Zero output 0001: HCLK 0010: PCLK 0011: HSIOSC 0100: LSI 0101: HSE 1000: RC150K 1001: RC10K                                                                                                                        |

### 5 Interrupt

#### 5.1 Overview

Nested Vectored Interrupt Controller (NVIC) for the ARM® Cortex®-M0+ core to manage interrupts and exceptions. The NVIC is tightly coupled to the processor core, enabling low-latency exception and interrupt handling.

The processor supports up to 32 interrupt request (IRQ) inputs and supports multiple internal exceptions.

This chapter only introduces the 32 external interrupt requests (IRQ0  $\sim$  IRQ31) of the processor. Please refer to the "ARM® Cortex®-M0+Technical Reference Manual" and "ARM® v6-M Architecture Reference Manual" for details of the processor's internal exceptions.

#### 5.2 Main features

- 16 inner exceptions
- 32 maskable external interrupts
- 4 programmable priorities
- Low-latency exception and interrupt handling
- Support for interrupt nesting
- Interrupt vector table remapping

### 5.3 Interrupt priority

The external interrupt can be set to 4 levels of priority, the highest priority is "0", the lowest priority is "3", and the default value is "0".

If a higher priority interrupt occurs while the processor is executing an interrupt handler, the interrupt is preempted. If an interrupt occurs with the same or lower priority as the interrupt being processed, the interrupt will not be preempted, but the state of the new interrupt will change to pending. If multiple pending interrupts have the same priority, the pending interrupt with the smaller interrupt number takes precedence. For example, if both IRQ [0] and IRQ [1] are pending, and both have the same priority, then IRQ [0] is processed first.



### 5.4 Interrupt vector table

When the ARM® Cortex®-M0+ responds to an interrupt, the processor automatically fetches the start address of the Interrupt Service Routine (ISR) from the interrupt vector table in the memory. The interrupt vector table includes the initial value of the main stack pointer (MSP), the entry address of the service routine for internal exceptions and external interrupts. Each interrupt vector occupies 1 word (4 bytes), and the storage address of the interrupt vector is the vector number multiplied by 4, as shown in the following table:

Table 5-1 Interrupt vector table

| Vector<br>number | External<br>interrupt<br>number<br>(IRQ#) | Priority     | Interrupt<br>source   | Introduction                                                       | Address          |
|------------------|-------------------------------------------|--------------|-----------------------|--------------------------------------------------------------------|------------------|
| 0                | -                                         | -            | -                     | MSP initial value                                                  | 0x0000 0000      |
| 1                | -                                         | -3           | Reset                 | Reset vector                                                       | 0x0000 0004      |
| 2                | -                                         | -2           | NMI                   | Non-maskable interrupt <sup>2</sup>                                | 0x0000 0008      |
| 3                | -                                         | -1           | HardFault             | Hardware error exception (fault)                                   | 0x0000 000C      |
| 4-10             | -                                         | -            | -                     | Reserved                                                           | 0x0000 0010~002B |
| 11               | -                                         | Configurable | SVCall                | Hypervisors invoked via SWI instructions                           | 0x0000 002C      |
| 12-13            | -                                         | -            | -                     | Reserved                                                           | 0x0000 0030~0037 |
| 14               | -                                         | Configurable | PendSV                | Suspendable requests for system services                           | 0x0000 0038      |
| 15               | -                                         | Configurable | SysTick               | System tick timer                                                  | 0x0000 003C      |
| 16               | 0                                         | Configurable | WDT                   | Windowed watchdog and independent watchdog interrupts <sup>1</sup> | 0x0000 0040      |
| 17               | 1                                         | Configurable | LVD                   | LVD global interrupt                                               | 0x0000 0044      |
| 18               | 2                                         | Configurable | RTC                   | RTC global interrupt                                               | 0x0000 0048      |
| 19               | 3                                         | Configurable | FLASHRAM <sup>1</sup> | FLASH/RAM global interrupt                                         | 0x0000 004C      |
| 20               | 4                                         | Configurable | RCC                   | RCC global interrupt <sup>3</sup>                                  | 0x0000 0050      |
| 21               | 5                                         | Configurable | GPIOA                 | GPIOA global interrupt                                             | 0x0000 0054      |
| 22               | 6                                         | Configurable | GPIOB                 | GPIOB global interrupt                                             | 0x0000 0058      |
| 23               | 7                                         | Configurable | GPIOC                 | GPIOC global interrupt <sup>1</sup>                                | 0x0000 005C      |
| 24               | 8                                         | Configurable | GPIOF                 | GPIOF global interrupt <sup>1</sup>                                | 0x0000 0060      |
| 25               | 9                                         | Configurable | DMA1                  | DMA channel 1 global interrupt                                     | 0x0000 0064      |
| 26               | 10                                        | Configurable | DMA23                 | DMA channel 2, DMA channel 3 global interrupt <sup>1</sup>         | 0x0000 0068      |
| 27               | 11                                        | Configurable | DMA4                  | DMA channel 4 global interrupt                                     | 0x0000 006C      |

| Vector<br>number | External<br>interrupt<br>number<br>(IRQ#) | Priority     | Interrupt<br>source | Introduction                                  | Address     |
|------------------|-------------------------------------------|--------------|---------------------|-----------------------------------------------|-------------|
| 28               | 12                                        | Configurable | ADC                 | ADC global interrupt                          | 0x0000 0070 |
| 29               | 13                                        | Configurable | ATIM                | ATIM global interrupt                         | 0x0000 0074 |
| 30               | 14                                        | Configurable | VC1                 | VC1 global interrupt                          | 0x0000 0078 |
| 31               | 15                                        | Configurable | VC2                 | VC2 global interrupt                          | 0x0000 007C |
| 32               | 16                                        | Configurable | GTIM1               | GTIM1 global interrupt                        | 0x0000 0080 |
| 33               | 17                                        | Configurable | GTIM2               | GTIM2 global interrupt                        | 0x0000 0084 |
| 34               | 18                                        | -            | -                   | Reserved                                      | 0x0000 0088 |
| 35               | 19                                        | -            | -                   | Reserved                                      | 0x0000 008C |
| 36               | 20                                        | Configurable | BTIM1               | BTIM1 global interrupt                        | 0x0000 0090 |
| 37               | 21                                        | Configurable | BTIM2               | BTIM2 global interrupt                        | 0x0000 0094 |
| 38               | 22                                        | Configurable | BTIM3               | BTIM3 global interrupt                        | 0x0000 0098 |
| 39               | 23                                        | Configurable | I2C                 | I2C global interrupt                          | 0x0000 009C |
| 40               | 24                                        | -            | -                   | Reserved                                      | 0x0000 00A0 |
| 41               | 25                                        | Configurable | SPI                 | SPI global interrupt                          | 0x0000 00A4 |
| 42               | 26                                        | -            | -                   | Reserved                                      | 0x0000 00A8 |
| 43               | 27                                        | Configurable | UART1               | UART1 global interrupt                        | 0x0000 00AC |
| 44               | 28                                        | Configurable | UART2               | UART2 global interrupt                        | 0x0000 00B0 |
| 45               | 29                                        | Configurable | UART3               | UART3 global interrupt                        | 0x0000 00B4 |
| 46               | 30                                        | Configurable | AWT                 | AWT global interrupt                          | 0x0000 00B8 |
| 47               | 31                                        | Configurable | FAULT               | HSE/LSE operation fail interrupt <sup>4</sup> | 0x0000 00BC |

#### Caution 1:

Since the interrupts of some peripherals multiplex an IRQ interrupt source, the user should first check the interrupt flag bit in the interrupt service routine to determine the peripheral that generates the interrupt.

#### Caution 2:

NMI is not used in CW32W031.

#### Caution 3:

HSE, LSE clock signal start-up failure and LSI, LSE, HSIOSC, HSE clock signal stability correspond to RCC global interrupt.

#### Caution 4:

The failure of the HSE or LSE clock signal during operation corresponds to a FAULT interrupt.



#### 5.5 Interrupt related registers

#### 5.5.1 NVIC interrupt enable and disable enable

The ARM® Cortex-M0+ processor supports up to 32 external interrupt sources, corresponding to the 32 enable bits of the interrupt enable setting register NIVC\_ISER and the 32 disable bits of the interrupt enable clear register NVIC\_ICER. Setting the enable bit to 1 enables interrupts; Set the disable bit to 1, disable interrupts.

The above NVIC interrupt enable is only for the processor NVIC, whether the interrupt of the peripheral is enabled is also controlled by the interrupt control register of the corresponding peripheral.

#### 5.5.2 NVIC interrupt pending and clear pending

When an interrupt occurs, if the system is processing an interrupt of the same priority or higher, the system will not process the interrupt immediately, but will set the interrupt status to pending and save it in the interrupt pending status register; The pending state will remain valid until the processor enters this interrupt processing, unless the pending state is manually cleared. When the processor begins to enter the interrupt processing, the hardware will automatically clear the corresponding interrupt pending state.

The user can set the status of this interrupt to the pending state by setting the corresponding bit of the interrupt pending setting register NVIC\_ISPR. If the system is not processing an interrupt with the same priority or higher priority, the interrupt will be immediately responded and deal with.

The user can set the state of this interrupt to the pending clear state by setting the corresponding bit of the interrupt pending clear register NVIC\_ICPR.

#### 5.5.3 NVIC interrupt priority

The interrupt priority control registers NVIC\_IPR0~NVIC\_IPR7 are used to set the interrupt priority of IRQ0~IRQ31. Each interrupt source uses 8 bits. In CW32W031, only the upper two bits are used, and up to 4 interrupt priorities can be set.

#### Caution:

The setting of the interrupt priority register of ARM® Cortex-M0+ should be before the interrupt is enabled. The user cannot change the interrupt priority after the interrupt is enabled, which will lead to unpredictable results.



95 / 572 Rev 1.0

#### 5.5.4 NVIC interrupt mask

In some special occasions, all interrupts need to be disabled, which can be realized by using the interrupt mask register PRIMASK. Only the lowest 1 bit of PRIMASK is valid. If this bit is set to 1, all external interrupts and exceptions except NMI and hardware error exceptions are disabled; after clearing to 0, it is allowed to respond to interrupts and exceptions. This bit defaults to 0 after reset.

ARM® Cortex-M0+ has dedicated ARM instructions for modifying PRIMASK register, CPSIE i and CPSID i, please refer to "ARM® v6-M Architecture Reference Manual" for details.

Assembly instruction example reference:

CPSIE i ; Clear PRIMASK (Enable interrupt)
CPSID i ; Set up PRIMASK (Disable interrupts)

C-language (Calling the CMSIS device driver library) Example reference:

void \_\_enable\_irq(void); //Clear PRIMASK
void \_\_disable\_irq(void); //Set up PRIMASK

#### 5.5.5 Peripheral interrupt enable

Peripheral modules generally have their own interrupt enable registers. When using interrupts, you must first enable the peripheral interrupt enable, and refer to *Table 5-1 Interrupt vector table* to enable the NVIC interrupt for the interrupt source. For the interrupt enable of specific peripherals, please refer to the description of the relevant peripheral modules.



**Rev 1.0** 

# 5.6 List of registers

NVIC base address: NVIC\_BASE = 0xE000 E000

Table 5-2 List of NVIC registers

| Register name | Register address  | Register description                              |
|---------------|-------------------|---------------------------------------------------|
| NVIC_ISER     | NVIC_BASE + 0x100 | IRQ0~IRQ31 Interrupt Enable Setting Register      |
| NVIC_ICER     | NVIC_BASE + 0x180 | IRQ0~IRQ31 Interrupt Enable Clear Register        |
| NVIC_ISPR     | NVIC_BASE + 0x200 | IRQ0~IRQ31 Interrupt Pending Setup Register       |
| NVIC_ICPR     | NVIC_BASE + 0x280 | IRQ0~IRQ31 Interrupt Pending Clear Register       |
| NVIC_IPR0     | NVIC_BASE + 0x400 | IRQ0~IRQ3 Interrupt Priority Control Register 0   |
| NVIC_IPR1     | NVIC_BASE + 0x404 | IRQ4~IRQ7 Interrupt Priority Control Register 1   |
| NVIC_IPR2     | NVIC_BASE + 0x408 | IRQ8~IRQ11 Interrupt Priority Control Register 2  |
| NVIC_IPR3     | NVIC_BASE + 0x40C | IRQ12~IRQ15 Interrupt Priority Control Register 3 |
| NVIC_IPR4     | NVIC_BASE + 0x410 | IRQ16~IRQ19 Interrupt Priority Control Register 4 |
| NVIC_IPR5     | NVIC_BASE + 0x414 | IRQ20~IRQ23 Interrupt Priority Control Register 5 |
| NVIC_IPR6     | NVIC_BASE + 0x418 | IRQ24~IRQ27 Interrupt Priority Control Register 6 |
| NVIC_IPR7     | NVIC_BASE + 0x41C | IRQ28~IRQ31 Interrupt Priority Control Register 7 |

# 5.7 Register description

See section 1 Documentation conventions for abbreviations used in register descriptions.

### 5.7.1 NVIC\_ISER Interrupt Enable Setting Register

Address offset: 0x100 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                            |
|-----------|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0      | SETIRQ | RW         | Set to enable external interrupt IRQ0~IRQ31; write "1" to set, write "0" is invalid.  [0]: IRQ0  [1]: IRQ1  [2]: IRQ2  [31]: IRQ31  The read value indicates the current interrupt enable state |

### 5.7.2 NVIC\_ICER Interrupt Enable Clear Register

Address offset: 0x180 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                            |
|-----------|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0      | CLRIRQ | RW         | Set to disable external interrupt IRQ0~IRQ31; write "1" to set, write "0" is invalid.  [0]: IRQ0  [1]: IRQ1  [2]: IRQ2  [31]: IRQ31 The read value indicates the current interrupt enable state |

### 5.7.3 NVIC\_ISPR Interrupt Pending Setup Register

Address offset: 0x200 Reset value: 0x0000 0000

| Bit field | Name    | Permission | Function description                                                                                                                                                                                       |
|-----------|---------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0      | SETPEND | RW         | Set the pending state of external interrupt IRQ0~IRQ31; write "1" to set, write "0" is invalid.  [0]: IRQ0  [1]: IRQ1  [2]: IRQ2  [31]: IRQ31 The read value indicates the current interrupt pending state |



### 5.7.4 NVIC\_ICPR Interrupt Pending Clear Register

Address offset: 0x280 Reset value: 0x0000 0000

| Bit field | Name    | Permission | Function description                                                                                                                                                                                           |
|-----------|---------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0      | CLRPEND | RW         | Clear the pending state of external interrupt IRQ0~IRQ31; write "1" to clear, write "0" is invalid.  [0]: IRQ0  [1]: IRQ1  [2]: IRQ2  [31]: IRQ31 The read value indicates the current interrupt pending state |

### 5.7.5 NVIC\_IPR0 Interrupt Priority Control Register 0

Address offset: 0x400 Reset value: 0x0000 0000

| Bit field | Name    | Permission | Function description                                                                       |
|-----------|---------|------------|--------------------------------------------------------------------------------------------|
| 31:30     | IPRIRQ3 | RW         | The priority of interrupt IRQ3, 00 has the highest priority and 11 has the lowest priority |
| 29:24     | RFU     | -          | Reserved bits, please keep the default value                                               |
| 23:22     | IPRIRQ2 | RW         | The priority of interrupt IRQ2, 00 has the highest priority and 11 has the lowest priority |
| 21:16     | RFU     | -          | Reserved bits, please keep the default value                                               |
| 15:14     | IPRIRQ1 | RW         | The priority of interrupt IRQ1, 00 has the highest priority and 11 has the lowest priority |
| 13:8      | RFU     | -          | Reserved bits, please keep the default value                                               |
| 7:6       | IPRIRQ0 | RW         | The priority of interrupt IRQ0, 00 has the highest priority and 11 has the lowest priority |
| 5:0       | RFU     | -          | Reserved bits, please keep the default value                                               |

### 5.7.6 NVIC\_IPR1 Interrupt Priority Control Register 1

Address offset: 0x404 Reset value: 0x0000 0000

| Bit field | Name    | Permission | Function description                                                                       |
|-----------|---------|------------|--------------------------------------------------------------------------------------------|
| 31:30     | IPRIRQ7 | RW         | The priority of interrupt IRQ7, 00 has the highest priority and 11 has the lowest priority |
| 29:24     | RFU     | -          | Reserved bits, please keep the default value                                               |
| 23:22     | IPRIRQ6 | RW         | The priority of interrupt IRQ6, 00 has the highest priority and 11 has the lowest priority |
| 21:16     | RFU     | -          | Reserved bits, please keep the default value                                               |
| 15:14     | IPRIRQ5 | RW         | The priority of interrupt IRQ5, 00 has the highest priority and 11 has the lowest priority |
| 13:8      | RFU     | -          | Reserved bits, please keep the default value                                               |
| 7:6       | IPRIRQ4 | RW         | The priority of interrupt IRQ4, 00 has the highest priority and 11 has the lowest priority |
| 5:0       | RFU     | -          | Reserved bits, please keep the default value                                               |

### 5.7.7 NVIC\_IPR2 Interrupt Priority Control Register 2

Address offset: 0x408 Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                        |
|-----------|----------|------------|---------------------------------------------------------------------------------------------|
| 31:30     | IPRIRQ11 | RW         | The priority of interrupt IRQ11, 00 has the highest priority and 11 has the lowest priority |
| 29:24     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 23:22     | IPRIRQ10 | RW         | The priority of interrupt IRQ10, 00 has the highest priority and 11 has the lowest priority |
| 21:16     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 15:14     | IPRIRQ9  | RW         | The priority of interrupt IRQ9, 00 has the highest priority and 11 has the lowest priority  |
| 13:8      | RFU      | -          | Reserved bits, please keep the default value                                                |
| 7:6       | IPRIRQ8  | RW         | The priority of interrupt IRQ8, 00 has the highest priority and 11 has the lowest priority  |
| 5:0       | RFU      | -          | Reserved bits, please keep the default value                                                |

# 5.7.8 NVIC\_IPR3 Interrupt Priority Control Register 3

Address offset: 0x40C Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                        |
|-----------|----------|------------|---------------------------------------------------------------------------------------------|
| 31:30     | IPRIRQ15 | RW         | The priority of interrupt IRQ15, 00 has the highest priority and 11 has the lowest priority |
| 29:24     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 23:22     | IPRIRQ14 | RW         | The priority of interrupt IRQ14, 00 has the highest priority and 11 has the lowest priority |
| 21:16     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 15:14     | IPRIRQ13 | RW         | The priority of interrupt IRQ13, 00 has the highest priority and 11 has the lowest priority |
| 13:8      | RFU      | -          | Reserved bits, please keep the default value                                                |
| 7:6       | IPRIRQ12 | RW         | The priority of interrupt IRQ12, 00 has the highest priority and 11 has the lowest priority |
| 5:0       | RFU      | -          | Reserved bits, please keep the default value                                                |

### 5.7.9 NVIC\_IPR4 Interrupt Priority Control Register 4

Address offset: 0x410 Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                        |
|-----------|----------|------------|---------------------------------------------------------------------------------------------|
| 31:30     | IPRIRQ19 | RW         | The priority of interrupt IRQ19, 00 has the highest priority and 11 has the lowest priority |
| 29:24     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 23:22     | IPRIRQ18 | RW         | The priority of interrupt IRQ18, 00 has the highest priority and 11 has the lowest priority |
| 21:16     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 15:14     | IPRIRQ17 | RW         | The priority of interrupt IRQ17, 00 has the highest priority and 11 has the lowest priority |
| 13:8      | RFU      | -          | Reserved bits, please keep the default value                                                |
| 7:6       | IPRIRQ16 | RW         | The priority of interrupt IRQ16, 00 has the highest priority and 11 has the lowest priority |
| 5:0       | RFU      | -          | Reserved bits, please keep the default value                                                |

### 5.7.10 NVIC\_IPR5 Interrupt Priority Control Register 5

Address offset: 0x414 Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                        |
|-----------|----------|------------|---------------------------------------------------------------------------------------------|
| 31:30     | IPRIRQ23 | RW         | The priority of interrupt IRQ23, 00 has the highest priority and 11 has the lowest priority |
| 29:24     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 23:22     | IPRIRQ22 | RW         | The priority of interrupt IRQ22, 00 has the highest priority and 11 has the lowest priority |
| 21:16     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 15:14     | IPRIRQ21 | RW         | The priority of interrupt IRQ21, 00 has the highest priority and 11 has the lowest priority |
| 13:8      | RFU      | -          | Reserved bits, please keep the default value                                                |
| 7:6       | IPRIRQ20 | RW         | The priority of interrupt IRQ20, 00 has the highest priority and 11 has the lowest priority |
| 5:0       | RFU      | -          | Reserved bits, please keep the default value                                                |

### 5.7.11 NVIC\_IPR6 Interrupt Priority Control Register 6

Address offset: 0x418 Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                        |
|-----------|----------|------------|---------------------------------------------------------------------------------------------|
| 31:30     | IPRIRQ27 | RW         | The priority of interrupt IRQ27, 00 has the highest priority and 11 has the lowest priority |
| 29:24     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 23:22     | IPRIRQ26 | RW         | The priority of interrupt IRQ26, 00 has the highest priority and 11 has the lowest priority |
| 21:16     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 15:14     | IPRIRQ25 | RW         | The priority of interrupt IRQ25, 00 has the highest priority and 11 has the lowest priority |
| 13:8      | RFU      | -          | Reserved bits, please keep the default value                                                |
| 7:6       | IPRIRQ24 | RW         | The priority of interrupt IRQ24, 00 has the highest priority and 11 has the lowest priority |
| 5:0       | RFU      | -          | Reserved bits, please keep the default value                                                |

# 5.7.12 NVIC\_IPR7 Interrupt Priority Control Register 7

Address offset: 0x41C Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                        |
|-----------|----------|------------|---------------------------------------------------------------------------------------------|
| 31:30     | IPRIRQ31 | RW         | The priority of interrupt IRQ31, 00 has the highest priority and 11 has the lowest priority |
| 29:24     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 23:22     | IPRIRQ30 | RW         | The priority of interrupt IRQ30, 00 has the highest priority and 11 has the lowest priority |
| 21:16     | RFU      | -          | Reserved bits, please keep the default value                                                |
| 15:14     | IPRIRQ29 | RW         | The priority of interrupt IRQ29, 00 has the highest priority and 11 has the lowest priority |
| 13:8      | RFU      | -          | Reserved bits, please keep the default value                                                |
| 7:6       | IPRIRQ28 | RW         | The priority of interrupt IRQ28, 00 has the highest priority and 11 has the lowest priority |
| 5:0       | RFU      | -          | Reserved bits, please keep the default value                                                |

# 6 RAM Memory

#### 6.1 Overview

CW32W031 integrates 8KB embedded RAM for users to use, which is used to store various data in the process of program execution. The starting address of the RAM is 0x2000 0000, and the data is stored in the little-endian mode in the RAM, that is, the lowest byte address space stores the least significant byte data of the data.

#### 6.2 Main features

- Support access in 3 widths of byte (8bit), half word (16bit) or full word (32bit)
- Zero latency, can be accessed by CPU and DMA at maximum system clock frequency
- Support parity check function



#### 6.3 RAM Memory operation

The RAM memory operations that the user can perform include: read operations and write operations.

The read and write operations of RAM support three-bit widths of 8bit, 16bit and 32bit. The user program can complete the read and write by directly accessing the absolute address, but it should be noted that the data bit width of read and write must be aligned with the corresponding address boundary, otherwise read and write the operation is invalid and will result in a HardFault hardware error exception.

#### 6.3.1 Read operation

The read operation supports 3 different bit widths, which can be read by direct access to the absolute address, but it should be noted that the read data bit width must be aligned with the corresponding address boundary.

Code example:

```
8bit read:
	tempdata = * ( ( uint8_t * ) 0x2000 0001 );
16bit read:
	tempdata = * ( ( uint16_t * ) 0x2000 0002 );
32bit read:
	tempdata = * ( ( uint32_t * ) 0x2000 0004 ).
```

#### 6.3.2 Write operation

The write operation supports 3 different bit widths, and data can be written by directly accessing the absolute address, but it should be noted that the written data bit width must be aligned with the corresponding address boundary.

Code example:

```
8bit write:

* ( ( uint8_t * ) 0x2000 0001 ) = 0x12;

16bit write:

* ( ( uint16_t * ) 0x2000 0002 ) = 0x1234;

32bit write:

* ( ( uint32_t * ) 0x2000 0004 ) = 0x1234 5678.
```



### 6.4 Parity check function

CW32W031 supports the parity check function of RAM. After power-on, the parity check function is enabled by default and cannot be configured by the user.

Each byte of RAM data is actually stored in a 9bit physical space, including 8bit data bits and 1bit parity bits.

When the CPU writes to the RAM, the parity check unit of the RAM calculates the check digit and writes it into the corresponding check digit space. When reading RAM data, the data is read together with the check digit. The CPU performs parity check on each byte of the data, and compares the calculated check digit with the read check digit. If they are consistent, it means that the data in the RAM is correct. If it is inconsistent, the parity error flag RAM\_ISR.PARITY is set. If the RAM parity error interrupt enables control bit RAM\_IER.PARITY is set to 1, the CPU will respond to the interrupt service. The user program can set RAM\_ICR.PARITY to 0 to clear the parity error flag.

The user can obtain the RAM address where the parity error occurs by reading the parity error address register RAM\_ADDR.

**Rev 1.0** 

# 6.5 List of registers

RAM base address: RAM\_BASE = 0x4002 2400

Table 6-1 List of RAM registers

| Register name | Register address | Register description              |
|---------------|------------------|-----------------------------------|
| RAM_IER       | RAM_BASE + 0x00  | Interrupt Enable Control Register |
| RAM_ADDR      | RAM_BASE + 0x04  | Parity Error Address Register     |
| RAM_ISR       | RAM_BASE + 0x08  | Interrupt Flag Register           |
| RAM_ICR       | RAM_BASE + 0x0C  | Interrupt Flag Clear Register     |

§ RAM Memory CW32W031

# 6.6 Register description

See section 1 Documentation conventions for abbreviations used in register descriptions.

### 6.6.1 RAM\_ADDR Parity Error Address Register

Address offset: 0x04 Reset value: 0x2000 0000

| Bit field | Name | Permission | Function description                                     |
|-----------|------|------------|----------------------------------------------------------|
| 31:0      | ADDR | RO         | The address of the RAM where the parity error is located |

### 6.6.2 RAM\_IER Interrupt Enable Control Register

Address offset: 0x00 Reset value: 0x0000 0001

| Bit field | Name   | Permission | Function description                                           |
|-----------|--------|------------|----------------------------------------------------------------|
| 31:2      | RFU    | -          | Reserved bits, please keep the default value                   |
| 1         | PARITY | RW         | RAM parity error interrupt enable control 0: Disable 1: Enable |
| 0         | EN     | RO         | RAM parity enable flag<br>0: Disable<br>1: Enable              |

### 6.6.3 RAM\_ISR Interrupt Flag Register

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                         |
|-----------|--------|------------|------------------------------------------------------------------------------|
| 31:1      | RFU    | -          | Reserved bits, please keep the default value                                 |
| 0         | PARITY | RO         | Parity error flag 0: No parity error occurred 1: A parity error has occurred |

§ RAM Memory CW32W031

# 6.6.4 RAM\_ICR Interrupt Flag Clear Register

Address offset: 0x0C Reset value: 0x0000 0001

| Bit field | Name   | Permission | Function description                                                              |
|-----------|--------|------------|-----------------------------------------------------------------------------------|
| 31:1      | RFU    | -          | Reserved bits, please keep the default value                                      |
| 0         | PARITY | R1W0       | Parity Error Flag Clear Control<br>W0: Clear parity error flag<br>W1: No function |

### 7 FLASH Memory

#### 7.1 Overview

CW32W031 integrates 64KB embedded FLASH for users to use, which can be used to store application programs and user data. The chip supports read, erase and write operations of FLASH memory, and supports erase and write protection and read protection; the chip has a built-in high-voltage BOOST circuit required for FLASH programming, and no additional programming voltage is required.

#### 7.2 Main features

- Support access in 3 widths of byte (8bit), half word (16bit) or full word (32bit)
- Supports read, erase and write operations
- Support erase and write protection, read protection
- Support low-power mode

### 7.3 FLASH Memory organization

CW32W031 integrates 64KB user-accessible FLASH memory, which is managed by paging of 512 bytes per page, with a total of 128 pages. Users can perform full-page erasing and byte-by-byte programming operations on FLASH.

In addition to the user-accessible 64KB FLASH memory, the CW32W031 also integrates a 2.5KB startup program memory, which solidified with BootLoader and other codes when it leaves the factory, and the user cannot access this memory.

# 7.4 FLASH memory read wait cycle configuration

The internal FLASH memory of CW32W031 supports the operation clock with the fastest frequency of 24MHz. When the configured HCLK frequency is greater than 24MHz, the number of inserted waiting HCLK cycles needs to be configured through the WAIT bit field of the FLASH control register FLASH\_CR2. The configuration rules are shown in the following table:

| FLASH_CR2.WAIT | The number of HCLK cycles waiting for the instruction fetch cycle | HCLK Frequency |
|----------------|-------------------------------------------------------------------|----------------|
| 000            | 0                                                                 | HCLK ≤ 24MHz   |
| 001            | 1                                                                 | HCLK ≤ 48MHz   |
| 010            | 2                                                                 | HCLK ≤ 72MHz   |

Table 7-1 FLASH read wait cycle configuration

#### Caution:

When configuring the FLASH read wait period, the FLASH configuration clock must be enabled first.



### 7.5 FLASH Memory operation

User-executable FLASH memory operations include: read operations, erase operations, and write (programming) operations.

The read and write operations of FLASH support 3 widths of 8bit, 16bit and 32bit. The user program can complete the read and write by directly accessing the absolute address, but it should be noted that the data bit width of read and write must be aligned with the corresponding address boundary, otherwise it will cause HardFault hardware error exception.



#### 7.5.1 Page Erase

The minimum unit of the page erase operation of FLASH is 1 page, that is, 512 bytes. After the page erase operation is completed, the data content of all address spaces of the page is 0xFF.

If the page erase operation is performed on the unlocked FLASH page, the operation will fail, and the FLASH\_ISR.PAGELOCK flag will be set by hardware. If the FLASH\_IER.PAGELOCK is set to 1, the CPU will execute the corresponding interrupt service routine. User can clear the FLASH\_ISR.PAGELOCK interrupt flag by setting FLASH\_ICR.PAGELOCK to 0.

If the program runs in FLASH, and the page erase operation is performed on the storage space of the page where the PC (program pointer) is located, the operation will fail, and the FLASH\_ISR.PC flag will be set by hardware. If FLASH\_IER.PC is set to 1, then The CPU will execute the corresponding interrupt service routine. The user can clear the FLASH\_ISR.PC interrupt flag by setting FLASH\_ICR.PC to 0.

FLASH page erase operation steps are as follows:

Step 1: Set the FLASH operation mode to page erase mode, and write 0x02 to the working mode bit field MODE of the FLASH control register FLASH\_CR1;

#### Caution:

The FLASH\_CR1 register has the KEY protection feature. The upper 16bit data of the written data must be 0x5A5A, otherwise it cannot be written.

Step 2: To unlock the erasure protection of the page to be erased, see *Table 7-2 FLASH\_PAGELOCK Erase lock protection*, write 1 to the lock bit field LOCKx corresponding to the erasing lock register FLASH\_PAGELOCK:

#### Caution:

The FLASH\_PAGELOCK register has the KEY protection feature. The upper 16bit data of the written data must be 0x5A5A, otherwise it cannot be written.

Step 3: Write any data to any address in the page to be erased, triggering the erase operation of the page.

#### Caution:

The write data bit width needs to be aligned with the corresponding address boundary.

Code example:

- Step 4: Wait for the erase to complete, and query the FLASH busy flag bit FLASH\_CR1.BUSY becomes 0;
- Step 5: To erase other pages, repeat steps 2 to 4;
- Step 6: After the erase operation is completed, if you want to restore the lock protection of FLASH, you need to write 0 to the lock bit field LOCKx corresponding to the erase/write lock register FLASH\_PAGELOCK to activate the lock protection function to protect the FLASH content from being erased by mistake;
- Step 7: Set the FLASH operation mode to read mode, and write 0x00 to the working mode bit field MODE of the FLASH control register FLASH\_CR1.



112 / 572 Rev 1.0

#### 7.5.2 Write operation

Based on the characteristics of embedded FLASH, the write operation can only rewrite the bit data in the FLASH memory from '1' to '0', but cannot be rewritten from '0' to '1'. Therefore, before writing data, the page where the corresponding address is located must be erased.

The following three principles must be followed for the FLASH write operation:

- Cannot write to the address whose data bit content is '0'
- Addresses within the locked area cannot be written to
- Cannot write to the address of the page where the PC (Program Pointer) is located

When the CW32W031 performs a write operation, it will check whether the contents of the storage space are all '1'. FLASH has three write operation bit widths of 8bit, 16bit and 32bit, and the number of bytes to be checked is 1Byte, 2Byte and 4Byte respectively.

If the internal storage space is not all '1', the write operation will fail, and the FLASH\_ISR.PROG flag will be set by hardware. If FLASH\_IER.PROG is set to 1, the CPU will execute the corresponding interrupt service routine. User can clear the FLASH\_ISR.PROG interrupt flag by setting FLASH\_ICR.PROG to 0.

If the storage space of the unlocked FLASH page is written, the operation will fail, and the FLASH\_ISR. PAGELOCK flag will be set by hardware. If FLASH\_IER.PAGELOCK is set to 1, the CPU will execute the corresponding interrupt service routine. User can clear the FLASH\_ISR.PAGELOCK interrupt flag by setting FLASH\_ICR.PAGELOCK to 0.

If the program runs in FLASH, and the write operation is performed on the storage space of the page where the PC (program pointer) is located, the operation will fail, and the FLASH\_ISR.PC flag will be set by hardware. If FLASH\_IER.PC is set to 1, the CPU will Execute the corresponding interrupt service routine. The user can clear the FLASH\_ISR.PC interrupt flag by setting FLASH\_ICR.PC to 0.



The FLASH write operation steps are as follows:

Step 1: Set the FLASH operation mode to write (programming) mode, and write 0x01 to the working mode bit field MODE of the FLASH control register FLASH\_CR1;

#### Caution:

The FLASH\_CR1 register has the KEY protection feature, the high 16bit data of the written data must be 0x5A5A, otherwise it cannot be written.

Step 2: To unlock the erasure protection of the page to be written, see *Table 7-2 FLASH\_PAGELOCK Erase lock protection*, write 1 to the lock bit field LOCKx corresponding to the erasing lock register FLASH\_PAGELOCK;

#### Caution:

The FLASH\_PAGELOCK register has the KEY protection feature. The upper 16bit data of the written data must be 0x5A5A, otherwise it cannot be written.

Step 3: Write the data to be written into the target address and trigger the FLASH write operation. Note that the bit width of the written data needs to be aligned with the corresponding address boundary;

8bit width code example:

```
*( ( uint8 t * ) 0x000000001 ) = 0x55;
```

16bit width code example:

32bit width code example:

```
*( ( uint32_t * ) 0x0000 0004 ) = 0x1234 5678;
```

- Step 4: Wait for the programming to be completed, query and wait for the FLASH busy flag bit FLASH\_CR1. BUSY to become 0;
- Step 5: If you need to write more data to the address range of the currently unlocked area, repeat steps 4 to 5; if the write address exceeds the address range of the current unlocked area, repeat steps 3 to 5;
- Step 6: After the write operation is completed, if you need to restore the lock protection of the FLASH, write 0 to the lock bit field LOCKx corresponding to the erase/write lock register FLASH\_PAGELOCK to activate the lock protection function to protect the FLASH content from being erased by mistake;
- Step 7: Set the FLASH operation mode to read mode, and write 0x00 to the working mode bit field MODE of the FLASH control register FLASH\_CR1.



114 / 572 Rev 1.0

### 7.5.3 Read operation

CW32W031 supports 3 different bit widths for the FLASH read operation, which can be read by direct access to the absolute address. Note that the read data bit width must be aligned with the corresponding address boundary.

8bit width code example:

```
tempdata = *( ( uint8_t * ) 0x0000 0001 );
```

16bit width code example:

32bit width code example:



**Rev 1.0** 

### 7.6 FLASH Memory protection

FLASH memory has erase and write protection and read protection functions.

The erasure protection includes lock page erasure protection and PC address page erasure protection. Pages in the protected state cannot be erased and written, which can avoid accidental rewriting of FLASH content.

The read protection takes the entire FLASH as the protection object, and does not support single-page protection, which can prevent the user code from being illegally read.

### 7.6.1 Erase and write protection

CW32W031 realizes the erasing and writing locking of FLASH pages by setting the erasing and writing lock register FLASH\_PAGELOCK. Pages in the locked state cannot be page erased or written.

The internal FLASH memory of CW32W031 is divided into 128 pages, and each 8 pages corresponds to a LOCKx lock bit of the FLASH\_PAGELOCK register. The LOCKx field has a total of 16 bits, which can realize the lock protection of all 128 pages of FLASH memory. The correspondence between the fields of the erasing lock register FLASH\_PAGELOCK and the FLASH lock page is shown in the following table:

Table 7-2 FLASH\_PAGELOCK Erase lock protection

| FLASH_PAGELOCK bit field name | Lock page         |
|-------------------------------|-------------------|
| LOCK15                        | Page120 – Page127 |
| LOCK14                        | Page112 – Page119 |
| LOCK13                        | Page104 – Page111 |
| LOCK12                        | Page96 – Page103  |
| LOCK11                        | Page88 – Page95   |
| LOCK10                        | Page80 – Page87   |
| LOCK9                         | Page72 – Page79   |
| LOCK8                         | Page64 – Page71   |
| LOCK7                         | Page56 - Page63   |
| LOCK6                         | Page48 - Page55   |
| LOCK5                         | Page40 - Page47   |
| LOCK4                         | Page32 - Page39   |
| LOCK3                         | Page24 - Page31   |
| LOCK2                         | Page16 - Page23   |
| LOCK1                         | Page8 - Page15    |
| LOCK0                         | Page0 - Page7     |

When performing page erasing and writing operations on FLASH, you must first unlock the corresponding page by setting the corresponding FLASH\_PAGELOCK.LOCKx bit field to 1. An example of the unlock operation is as follows:

```
Lock Page0-Page7 code example:

CW_FLASH->PAGELOCK = 0x5A5A 0000 | (CW_FLASH->PAGELOCK & 0x0000 FFFE);

Unlock Page32-Page39 code example:

CW_FLASH->PAGELOCK = 0x5A5A 0000 | (CW_FLASH->PAGELOCK | 0x0000 0010);
```

#### Caution:

The FLASH\_PAGELOCK register has the KEY protection feature. The upper 16bit data of the written data must be 0x5A5A, otherwise it cannot be written.

If the page erase or write operation is performed directly on the unlocked FLASH page, the operation will fail and an interrupt flag will be generated. Please refer to section 7.5.1 Page Erase and section 7.5.2 Write operation.

### 7.6.2 Erase and write PC page protection

The FLASH memory of CW32W031 supports the function of erasing and writing PC page protection.

When the user program runs FLASH, if the current program pointer PC is just within the range of the FLASH address page to be erased, the erase operation will fail, and the FLASH\_ISR.PC flag will be set by hardware. If FLASH\_IER.PC is set to 1, the CPU will execute the corresponding interrupt service routine. The user can clear the FLASH\_ISR.PC interrupt flag by setting FLASH\_ICR.PC to 0.



#### 7.6.3 Read protection

The CW32W031 supports the FLASH read protection function. After the read protection is set, the FLASH cannot be read by ISP or SWD. Read protection only supports whole-chip FLASH protection, and does not support page-by-page protection.

The read protection is divided into 4 protection levels. The current protection level can be obtained by reading the security bit field SECURITY of the FLASH control register FLASH\_CR1. The security bit field is a read-only attribute and cannot be modified. The read protection level can be set by the ISP command, please refer to the ISP programming documentation.

The CPU fetches instructions from FLASH and the program's read operation to FLASH is not affected by the FLASH read protection function.

The read protection function of FLASH is shown in the following table:

Protection level FLASH CR1.SECURITY Function description Read protection is not set. Level0 00 The FLASH can be read by SWD or ISP. FLASH content cannot be read by SWD or ISP. The protection level can be reduced to Level 0 through ISP Level1 01 or SWD. After the downgrade, the content in the FLASH is all 0xFF, that is, it is in the empty chip state of the whole chip erasing. FLASH content cannot be read by SWD or ISP. The protection level can only be lowered by ISP, but after Level2 10 the downgrade, the content in the FLASH is all 0xFF, that is, it is in an empty chip state of whole chip erasing. FLASH content cannot be read by SWD or ISP. Both ISP and SWD downgrade functions are disabled. Level3 11 At this protection level, the chip can only be programmed

Table 7-3 FLASH read protection

#### 7.6.4 FLASH memory programming

CW32W031 internal integrated FLASH memory supports FLASH erasing and programming through SWD or ISP. The SWD method is to use the debugging tool to erase and program the FLASH through the SWD interface. The ISP method is to erase and program the FLASH through the BootLoader code pre-installed before the chip leaves the factory. ISP provides fast and efficient in-circuit erasing and programming methods, please refer to ISP programming documentation.

once.

#### 7.7 Precautions

In order to operate FLASH correctly and improve the access efficiency and service life of FLASH, users need to pay attention to the following matters when programming applications:

Address Alignment Requirements

The address boundary is aligned, that is, the address when accessing FLASH with a 16-bit width must be an even address, and when using a 32-bit width, the address must be an address that is a multiple of 4.

Code example for correct address alignment:

#### Operation complete flag query

When the CPU fetches instructions from FLASH and runs, if the page erase/write operation to FLASH is performed, the CPU will automatically stop the next instruction access, and the hardware will automatically wait for the erase and write operation to complete (the FLASH\_CR1.BUSY status bit becomes 0), so the user program does not need to loop through the query operation completion flag to determine whether the operation is completed.

When the CPU fetches instructions from RAM and runs, if a page erase/write operation to FLASH is performed, the CPU will access the next instruction while performing the operation. In order to ensure the correct execution of the next instruction of the program, The user program must query the FLASH\_CR1. BUSY flag cyclically after the FLASH erase and write operations, until the FLASH\_CR1.BUSY flag becomes 0, and then the subsequent tasks can be performed.

Before entering DeepSleep mode, if the FLASH is performing an erase/write operation, you must wait for the FLASH\_CR1.BUSY flag bit to clear to 0, and make sure FLASH\_CR1.MODE is 0 at the same time.

#### Service life

Based on the characteristics of embedded FLASH, the number of operations and storage time of FLASH are limited. Users should try to avoid frequent erasing and writing operations on the FLASH memory of a certain page or address in the application program to ensure reliable data storage. Please refer to the datasheet for specific life data.

#### Data storage mode

The application of CW32W031 stipulates that data is stored in FLASH in little-endian mode, that is, the least significant byte data of the data is stored in the lowest byte address space.



Low power features

FLASH has the characteristics of low power consumption. By setting FLASH\_CR1.STANDBY to 1, FLASH can automatically enter a low power consumption state after the system enters DeepSleep mode, ensuring that the product has lower power consumption in low power consumption mode.



# 7.8 List of registers

FLASH base address: FLASH\_BASE = 0x4002 2000

Table 7-4 List of FLASH registers

| Register name  | Register address  | Register description          |
|----------------|-------------------|-------------------------------|
| FLASH_CR1      | FLASH_BASE + 0x00 | Control register 1            |
| FLASH_CR2      | FLASH_BASE + 0x04 | Control register 2            |
| FLASH_PAGELOCK | FLASH_BASE + 0x08 | Erase lock register           |
| FLASH_IER      | FLASH_BASE + 0x20 | Interrupt Enable Register     |
| FLASH_ISR      | FLASH_BASE + 0x24 | Interrupt Flag Register       |
| FLASH_ICR      | FLASH_BASE + 0x28 | Interrupt Flag Clear Register |

# 7.9 Register description

See section  ${\it 1}$  Documentation conventions for abbreviations used in register descriptions.

## 7.9.1 FLASH\_CR1 Control register 1

Address offset: 0x00 Reset value: 0x0000 0010

| Bit field | Name     | Permission | Function description                                                                                                                                                                                                                                                                                                                          |
|-----------|----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | KEY      | WO         | Only when KEY is 0x5A5A, the write operation of this register is valid                                                                                                                                                                                                                                                                        |
| 15:8      | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                  |
| 7:6       | SECURITY | RO         | Current protection level 00: Level0, ISP can read and write, SWD can read and write 01: Level1, ISP downgradable, SWD downgradable; Data cannot be read 10: Level2, ISP downgradable, SWD has no function; Data cannot be read 11: Level3, ISP has no function, SWD has no function; Data cannot be read                                      |
| 5         | BUSY     | RO         | Erase status flag 0: Erase operation completed 1: Erase operation is not completed                                                                                                                                                                                                                                                            |
| 4         | STANDBY  | RW         | Low power enable control 0: When the system enters DeepSleep mode, FLASH does not enter low power consumption mode 1: When the system enters DeepSleep mode, FLASH enters low power consumption mode Caution: It is recommended to configure this value to 1, otherwise it will cause the power consumption of DeepSleep mode to be too large |
| 3:2       | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                  |
| 1:0       | MODE     | RW         | Operation Mode Configuration 00: Read mode, Read 01: Write mode, Program 10: Page erase mode, PageErase 11: Chip erase mode, ChipErase                                                                                                                                                                                                        |

## 7.9.2 FLASH\_CR2 Control register 2

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                           |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | KEY  | WO         | Only when KEY is 0x5A5A, the write operation of this register is valid                                                                                                                                                                         |
| 15:3      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                   |
| 2:0       | WAIT | RW         | FLASH instruction fetches cycle configuration 000: 1 HCLK cycle for HCLK <= 24MHz 001: 2 HCLK cycle for 24MHz < HCLK <= 48MHz 010: 3 HCLK cycle for 48MHz < HCLK <= 72MHz Caution: This control bit has the same function as SYSCTRL_CR2[6:4]. |

# 7.9.3 FLASH\_PAGELOCK Erase lock register

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                       |
|-----------|--------|------------|--------------------------------------------------------------------------------------------|
| 31:16     | KEY    | WO         | Only when KEY is 0x5A5A, the write operation of this register is valid                     |
| 15        | LOCK15 | RW         | Page120 – Page127 erase lock configuration 0: locked, non-rewritable 1: open, rewritable   |
| 14        | LOCK14 | RW         | Page112 – Page119 erase lock configuration 0: locked, non-rewritable 1: open, rewritable   |
|           | •••    |            |                                                                                            |
| 1         | LOCK1  | RW         | Page8 – Page15 erase lock configuration 0: locked, non-rewritable 1: open, rewritable      |
| 0         | LOCK0  | RW         | Page0 – Page7 erase lock configuration<br>0: locked, non-rewritable<br>1: open, rewritable |

## 7.9.4 FLASH\_IER Interrupt Enable Register

Address offset: 0x20 Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                            |
|-----------|----------|------------|-------------------------------------------------------------------------------------------------|
| 31:5      | RFU      | -          | Reserved bits, please keep the default value                                                    |
| 4         | PROG     | RW         | Programming Error Interrupt Enable Control 0: Disable 1: Enable                                 |
| 3:2       | RFU      | -          | Reserved bits, please keep the default value                                                    |
| 1         | PAGELOCK | RW         | Erase and write PAGELOCK locked page interrupt enable control 0: Disable 1: Enable              |
| 0         | PC       | RW         | Erase and write the page where the PC is located, interrupt enable control 0: Disable 1: Enable |

## 7.9.5 FLASH\_ISR Interrupt Flag Register

Address offset: 0x24 Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                                                                                                                                                                              |
|-----------|----------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5      | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                      |
| 4         | PROG     | RO         | Programming error flag  0: The content of each byte of the current address to be written is all 0xFF  1: The content of each byte of the current address to be written is not all 0xFF                                                            |
| 3:2       | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                      |
| 1         | PAGELOCK | RO         | Erase and write PAGELOCK locked page interrupt flag 0: The current erase address is outside the page locked by PAGELOCK 1: The current erase address is within the page locked by PAGELOCK                                                        |
| 0         | PC       | RO         | Erase and write the interrupt flag of the page where the PC pointer is located  0: The current erase address is outside the page where the PC pointer is located  1: The current erase address is within the page where the PC pointer is located |

# 7.9.6 FLASH\_ICR Interrupt Flag Clear Register

Address offset: 0x28 Reset value: 0x0000 001F

| Bit field | Name     | Permission | Function description                                                                                                                                                                    |
|-----------|----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5      | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                            |
| 4         | PROG     | WO         | Programming error flag clear<br>W0: Clear programming error flag<br>W1: No function                                                                                                     |
| 3:2       | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                            |
| 1         | PAGELOCK | R1W0       | Erase and write PAGELOCK locked page interrupt flag clear W0: Clear the page interrupt flag locked by erasing PAGELOCK W1: No function                                                  |
| 0         | PC       | R1W0       | Erase and write the page where the PC pointer is located to clear the interrupt flag W0: Clear and erase the interrupt flag of the page where the PC pointer is located W1: No function |

# 8 Direct memory access (DMA)

#### 8.1 Overview

The CW32W031 supports Direct Memory Access (DMA), which enables high-speed data transfer between peripherals and memory, between peripherals and peripherals, and between memory and memory without CPU intervention. The priority arbiter inside the DMA controller can realize the arbitration of DMA and CPU control of peripheral bus, as well as the scheduling execution between multiple DMA channels.

#### 8.2 Main features

- 4 independent DMA channels
- 3 data transfer widths: 8bit, 16bit, 32bit
- 4 transfer modes: Software BLOCK, Software BULK, Hardware BLOCK, Hardware BULK
- Source address and destination address type: peripherals, memory
- Address increment method: fixed, auto-increasing
- Number of data blocks to be transferred: 1~65535
- Addressing range: 0x0000 0000 ~ 0xFFFF FFFF

# 8.3 Functional block diagram

The AHB bus of the DMA controller is connected to the AHB bus of the peripheral through the bus matrix to realize the data interconnection between the DMA and the peripheral, including FLASH, SRAM, CRC, GPIO and various APB devices. The functional block diagram of the DMA controller is shown in the following figure:



Figure 8-1 DMA functional block diagram

- DMA controller
  - 4 independent DMA channels, the channel priority is bound to the channel number, the smaller the channel number, the higher the priority, and the larger the channel number, the lower the priority.
- Bus Matrix

Both the CPU system bus and the DMA bus interface are connected to the bus matrix, and are switched and connected to peripherals through the bus matrix. When the CPU and DMA access different AHB bus devices or AHB to APB bridges, data transfer can be performed simultaneously; When the CPU and DMA access the same AHB device at the same time (different devices under the AHB to APB bridge are also considered to be the same AHB device), the CPU has a higher priority than the DMA.

AHB to APB bridge

DMA can achieve access to APB devices through the bus matrix and AHB to APB bridges. All APB devices under the same AHB-to-APB bridge share the same AHB bus and are therefore regarded as the same AHB device. When the CPU and DMA access the APB device under the same AHB to APB bridge at the same time (whether accessing the same APB device or a different APB device), the priority of the CPU is higher than that of the DMA.

#### 8.4 DMA transfer modes

#### 8.4.1 Overview of Transfer Modes

DMA supports 4 transfer modes: software-triggered BLOCK transfer mode, software-triggered BULK transfer mode, hardware-triggered BULK transfer mode.

#### Software and hardware triggering

Some peripherals support hardware DMA. When they are configured as the trigger source of the DMA channel, a DMA request (DMA request) can be generated, and the hardware triggers the DMA transfer without CPU participation. Peripherals that do not support hardware DMA can only be configured as software-triggered DMA transfers.

The trigger mode is controlled by the TYPE bit field of the DMA trigger source control register DMA\_TRIGy (y is the DMA channel number,  $y=1\sim4$ , the same below), TYPE is 0 for software trigger mode, TYPE is 1 for hardware trigger mode.

#### Transfer modes of BLOCK and BULK

The difference between BLOCK and BULK transfer modes is whether the transfer is allowed to be interrupted by a higher priority transfer request (high priority DMA or CPU). The TRANS bit field of the DMA control and status register DMA\_CSRy is 1 for the BLOCK transmission mode, and 0 for the BULK transmission mode.

In BULK transmission mode, all data transmission will be completed at one time. No transfer gaps are inserted during data transfer, and the transfer process is not interrupted by CPU or other high-priority DMA channel transfer requests.

In the BLOCK transmission mode, a transmission gap is inserted after each data block is transmitted, and the arbiter performs transmission priority arbitration in the transmission gap. If a CPU or higher priority DMA channel wants to access the peripheral occupied by the current DMA channel, the arbiter will release the control right of the current DMA channel to the device, allowing the CPU or higher priority DMA channel to have priority access, etc. After completion, resume the previously interrupted DMA channel transfer.

The transfer modes of DMA as shown in the following table:

Table 8-1 DMA transfer mode

| Transfer mode  | DMA_TRIGy.TYPE | DMA_CSRy.TRANS | Can it be interrupted by a higher priority DMA channel or CPU? |
|----------------|----------------|----------------|----------------------------------------------------------------|
| Software BLOCK | 0              | 1              | YES                                                            |
| Software BULK  | 0              | 0              | NO                                                             |
| Hardware BLOCK | 1              | 1              | YES                                                            |
| Hardware BULK  | 1              | 0              | NO                                                             |

#### **DMA transfer process**

For a complete DMA transfer process, the user needs to do the following settings:

- Step 1: Set the transfer mode, DMA\_CSRy.TRANS is set to 1 for the BLOCK transfer mode, and 0 for the BULK transfer mode;
- Step 2: Set the trigger mode, DMA\_TRIGy.TYPE is set to 0 for software trigger, and 1 is for hardware trigger mode:
- Step 3: Configure DMA channel data transmission bit width, DMA\_CSRy.SIZE, select 8, 16, 32bit;
- Step 4: Configure the number of DMA channels to transmit data blocks, DMA\_CNTy.CNT, the valid range is  $1\sim65535$ ;
- Step 5: Configure the DMA channel transfer data block size, DMA\_CNTy.REPEAT, please write 1;
- Step 6: Configure the DMA transfer source address, DMA\_SRCADDRy;
- Step 7: Configure the DMA transfer destination address, DMA\_DSTADDRy;
- Step 8: Configure the DMA source address increment method, DMA\_CSRy.SRCINC, fixed or automatically incremented;
- Step 9: Configure the DMA destination address increment method, DMA\_CSRy.DSTINC, fixed or automatically increased;
- Step 10: Set DMA\_CSRy.EN to 1 to enable the corresponding DMA channel;
- Step 11: For software-triggered DMA transfer, set DMA\_TRIGy.SOFTSRC to start DMA transfer. For hardware-triggered DMA transfer, no setting is required, but only the peripherals used to start DMA need to be set correctly.

#### 8.4.2 Software trigger BLOCK transfer mode

Setting DMA\_TRIGy.SOFTSRC to 1 will immediately trigger the DMA channel for data transfer.

Each time a DMA channel completes a data block transmission, the DMA inserts a transmission gap, and the arbiter performs transmission priority arbitration in the transmission gap. If there is a CPU or higher priority DMA request to access the AHB device occupied by the current DMA channel during the transmission gap, the arbiter will release the control right of the current DMA channel to the device, allowing the CPU or higher priority The DMA channel has priority access; when the CPU or a higher priority DMA channel releases the device access right, the unfinished data transfer of this DMA channel will continue.

DMA\_TRIGy.SOFTSRC is automatically cleared after the transfer is completed.

The software triggers the BLOCK transmission mode, and transmits 3 data with a data width of 16 bits (DMA\_CNTy.REPEAT=1, DMA\_CNTy.CNT=3), where SA represents the source address, DA represents the destination address, and both the source address and the destination address are addresses. In auto-increment mode, the transmission process is shown in the following figure:



Figure 8-2 Software trigger BLOCK transfer mode

#### 8.4.3 Software trigger BULK transfer mode

Setting DMA\_TRIGy.SOFTSRC to 1 will immediately trigger DMA for data transfer. After the DMA channel transmits DMA\_CNTy.CNT data blocks, stop the transfer and release the peripheral occupancy rights. After the transfer is completed, DMA\_TRIGy.SOFTSRC is automatically cleared to zero.

Software-triggered BULK transfer mode has no transfer gap. Before the DMA\_CNTy.CNT data block transfer is completed, the DMA channel will always occupy the peripheral. The CPU or higher priority DMA channel can only access the peripheral after the DMA transfer is completed. Assume.

In user applications, it is recommended not to transfer too much data at a time, otherwise the CPU may be completely unable to access the peripherals occupied by the DMA channel for a period of time.

The software triggers the BULK transfer mode, and transmits 3 data with a data width of 16 bits (DMA\_CNTy. REPEAT=1, DMA\_CNTy.CNT=3), where SA represents the source address, DA represents the destination address, and both the source address and the destination address are addresses. In auto-increment mode, the transmission process is shown in the following figure:



Figure 8-3 Software trigger BULK transfer mode

#### 8.4.4 Hardware trigger BLOCK transfer mode

When the peripheral corresponding to the DMA channel generates a hardware trigger request signal, the DMA will transmit one data block, and then wait for the next hardware trigger request signal until all the data volume configured in the DMA controller is transmitted. For the hardware trigger request signal supported by the DMA channel, please refer to the HARDSRC bit field of the trigger source control register DMA\_TRIGy.

Like the software BLOCK transmission mode, DMA will insert a transmission gap while the hardware BLOCK transmission mode a data block is completed, allowing the CPU or higher-priority DMA channel transmission requests to preempt peripheral control.

The hardware triggers the BLOCK transmission mode, and transmits 3 data with a data width of 8 bits (DMA\_CNTy.REPEAT=1, DMA\_CNTy.CNT=3), where SA represents the source address, DA represents the destination address, the source address is fixed, and the destination address is incremented automatically, the transmission process is shown in the following figure:



Figure 8-4 Hardware trigger BLOCK transfer mode

#### 8.4.5 Hardware trigger BULK transfer mode

When the peripheral corresponding to the DMA channel generates a hardware trigger request signal, it will immediately trigger the DMA for data transmission. After the DMA channel transmits DMA\_CNTy.CNT data blocks, the transmission will be stopped and the peripheral occupancy will be released.

There is no transmission gap in the hardware-triggered BULK transfer mode. Before the transfer of DMA\_CNTy.CNT data block is completed, the DMA will always occupy the peripheral access right. The CPU or higher priority DMA channel can only access the peripheral after the operation is completed.

In user applications, it is recommended not to transfer too much data at a time, otherwise the CPU may be completely unable to access the peripherals occupied by the DMA channel for a period of time.

For the hardware trigger request signal supported by the DMA channel, see HARDSRC bit field in section 8.8.4 DMA\_TRIGy channel y trigger suorce control register.

The hardware triggers the BULK transmission mode, and transmits 3 data with a data width of 8 bits (DMA\_CNTy.REPEAT=1, DMA\_CNTy.CNT=3), where SA represents the source address, DA represents the destination address, the source address is auto-increasing, and the destination address is fixed, the transmission process is shown in the following figure:



Figure 8-5 Hardware trigger BULK transfer mode

134 / 572 Rev 1.0

### 8.5 Other configuration of DMA

#### 8.5.1 Data width

The data bit width can be set to 8bit, 16bit, 32bit, which can be set through the SIZE bit field of the DMA\_CSRy register. The data bit width should be exactly the same as the bit width of the source address and destination address of the DMA channel.

#### 8.5.2 Data block size

The data block size is configured through the REPEAT bit field of the DMA\_CNTy register, and it is recommended to write 1.

#### Caution:

The value of this bit field will automatically become 0 after each transfer, and needs to be written to 1 before the next DMA transfer.

#### 8.5.3 Number of data blocks

The number of data blocks to be transferred can be set from 1 to 65535, which is configured through the CNT bit field of the DMA\_CNTy register.

### 8.5.4 Channel priority

The priority of the 4 DMA channels is bound to the channel number. The smaller the channel number, the higher the priority, and the larger the channel number, the lower the priority.

101

### 8.6 DMA interrupt

The DMA channel can generate two interrupt flags during the transfer process: the transfer error interrupt flag and the transfer completion interrupt flag.

The interrupts of different DMA channels are independent, and the interrupt flag of each channel can be obtained through the interrupt flag register DMA\_ISR. The channel transmission error interrupt flag corresponds to multiple possible causes. The specific causes need to query the DMA\_CSRy.STATUS status bit, as shown in the following table:

DMA\_CSRy.STATUS status bitDMA Current state of channel y000Initial state001Transmission error, transmission address out of addressing range010Transmission error, aborted by transmission stop request011Transmission error, error accessing the transmission source address100Transmission error, error accessing the transmission destination address

Table 8-2 DMA Interrupt Flag Status Bits

When the transmission error interrupt flag or the transmission completion interrupt flag is set, if the corresponding interrupt request is enabled, the CPU will execute the interrupt service routine. Before exiting the interrupt service routine, the corresponding flag should be cleared to avoid repeatedly entering the interrupt service routine.

Transfer completed

The DMA interrupt trigger conditions, interrupt enable and interrupt flag clearing methods are shown in the following table:

Interrupt enable Interrupt flag DMA interrupt type Triggering conditions method clearing method The transfer address is out of the addressing range; Or, the peripheral requests to Set DMA\_CSRy.TEIE to 1 Transmission error abort the DMA transfer; Set DMA ICR.TEy to 0 Or, there is an error accessing the transfer source/destination address The data transfer is all done Transfer completed Set DMA\_CSRy.TCIE to 1 Set DMA\_ICR.TCy to 0 correctly

Table 8-3 DMA Interrupt flag and clear method

# 8.7 List of registers

DMA base address: DMA\_BASE = 0x4002 0000

Table 8-4 List of DMA registers

| Register name | Register address       | Register description                                     |
|---------------|------------------------|----------------------------------------------------------|
| DMA_ISR       | DMA_BASE + 0x00        | Interrupt Flag Register                                  |
| DMA_ICR       | DMA_BASE + 0x04        | Interrupt Flag Clear Register                            |
| DMA_CSRy      | DMA_BASE + 0x00 + 32×y | Channel y control and status register, y = 1~4           |
| DMA_CNTy      | DMA_BASE + 0x04 + 32×y | Channel y transfer number register, y = 1~4              |
| DMA_SRCADDRy  | DMA_BASE + 0x08 + 32×y | Channel y transfer source address register, y = 1~4      |
| DMA_DSTADDRy  | DMA_BASE + 0x0C + 32×y | Channel y transfer destination address register, y = 1~4 |
| DMA_TRIGy     | DMA_BASE + 0x10 + 32×y | Channel y trigger source control register, y = 1~4       |

# 8.8 Register description

See section 1 Documentation conventions for abbreviations used in register descriptions.

## 8.8.1 DMA\_ISR Interrupt Flag Register

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                            |
|-----------|------|------------|---------------------------------------------------------------------------------|
| 31:14     | RFU  | -          | Reserved bits, please keep the default value                                    |
| 13        | TE4  | RO         | Channel 4 Transmission Error Flag See TE1 description                           |
| 12        | TC4  | RO         | Channel 4 Transfer Complete Flag See TC1 description                            |
| 11:10     | RFU  | -          | Reserved bits, please keep the default value                                    |
| 9         | TE3  | RO         | Channel 3 Transmission Error Flag See TE1 description                           |
| 8         | TC3  | RO         | Channel 3 Transfer Complete Flag See TC1 description                            |
| 7:6       | RFU  | -          | Reserved bits, please keep the default value                                    |
| 5         | TE2  | RO         | Channel 2 Transmission Error Flag See TE1 description                           |
| 4         | TC2  | RO         | Channel 2 Transfer Complete Flag See TC1 description                            |
| 3:2       | RFU  | -          | Reserved bits, please keep the default value                                    |
| 1         | TE1  | RO         | Channel 1 Transmission Error Flag 0: Normal transmission 1: Transmission error  |
| 0         | TC1  | RO         | Channel 1 Transfer Complete Flag 0: Transfer not complete 1: Transfer completed |

# 8.8.2 DMA\_ICR Interrupt Flag Clear Register

Address offset: 0x04 Reset value: 0xFFFF FFFF

| Bit field | Name | Permission | Function description                                                                                        |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------|
| 31:14     | RFU  | -          | Reserved bits, please keep the default value                                                                |
| 13        | TE4  | R1W0       | Channel 4 Transmission Error Flag Clear<br>See TE1 description                                              |
| 12        | TC4  | R1W0       | Channel 4 Transfer Complete Flag Cleared See TC1 description                                                |
| 11:10     | RFU  | -          | Reserved bits, please keep the default value                                                                |
| 9         | TE3  | R1W0       | Channel 3 Transmission Error Flag Clear<br>See TE1 description                                              |
| 8         | TC3  | R1W0       | Channel 3 Transfer Complete Flag Cleared See TC1 description                                                |
| 7:6       | RFU  | -          | Reserved bits, please keep the default value                                                                |
| 5         | TE2  | R1W0       | Channel 2 Transmission Error Flag Clear<br>See TE1 description                                              |
| 4         | TC2  | R1W0       | Channel 2 Transfer Complete Flag Cleared See TC1 description                                                |
| 3:2       | RFU  | -          | Reserved bits, please keep the default value                                                                |
| 1         | TE1  | R1W0       | Channel 1 Transmission Error Flag Clear<br>W0: Clear channel 1 transmission error flag<br>W1: No function   |
| 0         | TC1  | R1W0       | Channel 1 Transfer Complete Flag Cleared<br>W0: Clear channel 1 transfer completion flag<br>W1: No function |

## 8.8.3 DMA\_CSRy Channel y Control and Status Register

Address offset:  $0x00 + 32 \times y$  Reset value: 0x0000 0000 (y = 1~4)

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                             |
|-----------|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11     | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                     |
| 10:8      | STATUS | RW         | Current state of channel y 000: Initial state 001: Transmission error, transmission address out of addressing range 010: Transmission error, aborted by transmission stop request 011: Transmission error, error accessing the transmission source address 100: Transmission error, error accessing the transmission destination address 101: Transfer completed |
| 7:6       | SIZE   | RW         | Channel y transmission data bit width configuration 00: 8bit 01: 16bit 10: 32bit                                                                                                                                                                                                                                                                                 |
| 5         | DSTINC | RW         | Channel y destination address incremental configuration 0: Fixed destination address 1: Destination address auto increment                                                                                                                                                                                                                                       |
| 4         | SRCINC | RW         | Channel y source address incremental configuration 0: Source address fixed 1: Source address auto increment                                                                                                                                                                                                                                                      |
| 3         | TRANS  | RW         | Channel y transfer mode configuration 0: Bulk transfer (BULK) 1: Block transfer (BLOCK)                                                                                                                                                                                                                                                                          |
| 2         | TEIE   | RW         | Channel y transmission error interrupt enable control 0: Disable 1: Enable                                                                                                                                                                                                                                                                                       |
| 1         | TCIE   | RW         | Channel y transfer completion interrupt enable control 0: Disable 1: Enable                                                                                                                                                                                                                                                                                      |
| 0         | EN     | RW         | Channel y enable control 0: Disable 1: Enable                                                                                                                                                                                                                                                                                                                    |

## 8.8.4 DMA\_TRIGy channel y trigger suorce control register

Address offset:  $0x10 + 32 \times y$  Reset value: 0x0000 0000 (y = 1~4)

| Bit field | Name    | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|---------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8      | RFU     | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7:2       | HARDSRC | RW         | Channel y hardware trigger signal trigger source configuration 000000: UART1 receive Buf non-empty flag 000001: UART1 send Buf empty flag 000010: UART2 receive Buf non-empty flag 000010: UART2 send Buf empty flag 000100: UART3 receive Buf non-empty flag 000101: UART3 send Buf empty flag 000101: UART3 send Buf empty flag 000110: SPI receive Buf non-empty flag 000111: SPI send Buf empty flag 000111: SPI send Buf empty flag 001101: ADC conversion complete flag 001101: BTIM1 overflow interrupt flag 001101: BTIM2 overflow interrupt flag 001100: BTIM1 trigger interrupt flag 001110: BTIM2 trigger interrupt flag 001101: BTIM3 overflow interrupt flag 001000: ATIM CHXA, CH4 compare capture flags, event update flag 010010: ATIM CHXB compare capture flags, event update flag 010010: GTIM1 trigger interrupt flag 010101: GTIM1 channel 1 compare capture interrupt flag 010101: GTIM1 channel 2 compare capture interrupt flag 010101: GTIM1 channel 3 compare capture interrupt flag 011010: GTIM1 channel 4 compare capture interrupt flag 011011: GTIM2 channel 4 compare capture interrupt flag 011011: GTIM2 channel 1 compare capture interrupt flag 011011: GTIM2 channel 2 compare capture interrupt flag 011011: GTIM2 channel 3 compare capture interrupt flag 01101: GTIM2 channel 3 compare capture interrupt flag 01101: GTIM2 channel 3 compare capture interrupt flag 01101: GTIM2 channel 3 compare capture interrupt flag 01110: GTIM2 channel 3 compare capture interrupt flag 01110: GTIM2 channel 4 compare capture interrupt flag 01110: GTIM2 channel 3 compare capture interrupt flag 01110: GTIM2 channel 4 compare capture interrupt flag 01110: GTIM2 channel 4 compare capture interrupt flag 01110: GTIM2 channel 3 compare capture interrupt flag 01110: GTIM2 channel 4 compare capture interrupt flag 01110: GTIM2 channel 4 compare capture interrupt flag 01110: GTIM2 channel 4 compare captur |
| 1         | SOFTSRC | RW         | Channel y software trigger control R0: Transfer completed R1: Transfer in progressing W0: No function W1: Trigger the channel immediately to start the transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0         | TYPE    | RW         | Channel y trigger type configuration 0: Software trigger mode, the transmission is initiated by the SOFTSRC signal 1: In hardware trigger mode, the transmission is initiated by the trigger signal of the trigger source configured by HARDSRC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

### 8.8.5 DMA\_CNTy Channel y transfer number register

Address offset:  $0x04 + 32 \times y$  Reset value: 0x0000 0000 (y = 1~4)

| Bit field | Name   | Permission | Function description                                                                                                                                                                       |
|-----------|--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20     | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                               |
| 19:16     | REPEAT | RW         | Please write 1                                                                                                                                                                             |
| 15:0      | CNT    | RW         | Configure the amount of data to be transmitted by channel y as CNT During the transmission process, the value of this register is decremented by 1 each time the transmission is completed |

### 8.8.6 DMA\_SRCADDRy Channel y transfer source address register

Address offset:  $0x08 + 32 \times y$  Reset value: 0x0000 0000 (y = 1~4)

| Bit field | Name    | Permission | Function description                  |
|-----------|---------|------------|---------------------------------------|
| 31:0      | SRCADDR | RW         | Channel y transmission source address |

#### Caution:

The destination address cannot be a DMA register, a FLASH register, or a RAM register.

### 8.8.7 DMA\_DSTADDRy Channel y transfer destination address register

Address offset:  $0x0C + 32 \times y$  Reset value: 0x0000 0000 (y = 1~4)

| Bit field | Name    | Permission | Function description                       |
|-----------|---------|------------|--------------------------------------------|
| 31:0      | DSTADDR | RW         | Channel y transmission destination address |

#### Caution:

The destination address cannot be a DMA register, a FLASH register, or a RAM register.



# 9 General-purpose input/output (GPIO)

### 9.1 Overview

The GPIO controller realizes the connection between various digital and analog circuits inside the chip and the physical pins.

GPIO can be configured as digital input and output and analog functions, supports peripheral function multiplexing, supports 2 interrupt sources of rising edge and falling edge, can wake up the MCU return to active mode through external interrupt in DeepSleep mode.

#### 9.2 Main features

- All registers are read and written through the AHB bus interface
- With digital input and output and analog function
- Digital input and output support common GPIO and function multiplexing
- The analog function can be used as the input signal of ADC, VC, LVD
- Support a variety of internal clock signal output
- Digital input supports internal pull-up, pull-down and high-impedance modes
- Digital outputs support push-pull and open-drain modes
- The digital output supports atomic bit operations of bit setting, bit clearing, and bit flipping
- Interrupt function supports rising edge, falling edge trigger mode
- Interrupts with digital filtering, selectable from 8 clock sources
- Supports wake-up of MCU via external interrupt in DeepSleep mode

# 9.3 Function description

# 9.3.1 Functional block diagram

The functional block diagram of the GPIO controller is shown in the following figure:

Analogue fuction HCLK/2 HCLK/4 VDD HCLK/8 Input drive unit BTIM1 Interrupt Filter Clock Selection RC150K LSI RC10K Protection AWT overflow diode Digital filter FLITER ΡU Interrupt Peripheral multiplexing ADS function input IO Pin Read VSS IDR Q D D Q ō Q PD **HCLK** Output drive unit VDD BRR BSRR TOC Protection ODR diode Read/Write Output control VSS Peripheral multiplexing function input Push-pull/ VSS Open-drain/Disable

Figure 9-1 GPIO functional block diagram

### 9.3.2 Digital output

Clear the analog-digital configuration register  $GPIOx\_ANALOG[y]$  (x is the GPIO port number, x=A, B, C, F; y is the pin number, y=0~15; the same below), and configure the corresponding GPIO port as Digital function; clear the input and output direction register  $GPIOx\_DIR[y]$  to configure the GPIO port as output mode. Digital output signal sources can be

- Output data register GPIOx\_ODR
- On-chip digital peripherals

Configure the output mode through the output mode register GPIOx\_OPENDRAIN, which can select push-pull output or open-drain output.

#### 9.3.3 Digital input

Clear the analog-digital configuration register GPIOx\_ANALOG[y] to configure the GPIO port as a digital function; set the input and output direction register GPIOx\_DIR[y] to configure the corresponding GPIO port as input mode. Digital input signals are configurable:

- Reach the input data register GPIOx\_IDR
- Reach on-chip digital peripherals
- Trigger interrupt

In this mode, the digital input signal is directed to the internal digital input circuit through the ADS switch.

After the level state is confirmed by the Schmitt trigger, it can be directly sent to the input of the digital peripheral pointed to by the on-chip multiplexing function, or through an HCLK-based synchronizer, present on the input data register GPIOx\_IDR [y].

The bits of the GPIOx\_IDR register and the previous latch form a synchronizer, which can avoid the signal instability caused by the pin level jumping during the system clock change, but it will cause a certain read delay. The synchronization timing of the read port pins is shown in the following figure:



Figure 9-2 Read Port Pin Synchronization Timing

In the clock cycle after the rising edge of the system clock, the pin level signal will be latched in the internal register, as shown in the shaded part in the figure, after the next rising edge of the system clock, the stable pin level signal is read, and then a on the rising edge of the system clock, the data is latched into the GPIOx\_IDR register. The signal delay  $T_{pd}$  is  $1\sim2$  system clocks.

The built-in hardware filter circuit can also be enabled if this input signal is considered for triggering an interrupt. The filter circuit is implemented based on a double D flip-flop synchronizer, which has seven clock sources, some of which are specific to the low-power mode. For example, a key debounce operation without software intervention can be easily implemented. For specific clock source options and edge trigger options, see section 9.3.6 Interrupt Function.

In this mode, the internal pull-up and pull-down functions can be individually selected to be turned on or off through the pull-up resistor register GPIOx\_PUR and the pull-down resistor register GPIOx\_PDR.

#### 9.3.4 Analogue function

For a GPIO port configured with analog function, you can open the GPIO analog signal channel by setting the analog digital configuration register GPIOx\_ANALOG[y] to 1. When the GPIO analog signal channel is turned on, the digital function of the port is turned off, the internal pull-up and pull-down are disconnected, the internal digital input signal is shorted to VSS through the ADS switch, and the internal digital output function is disabled.

#### 9.3.5 Multiplexing function

The multiplexing function of the input and output ports can be realized through the multiplexing function registers (GPIOx\_AFRH and GPIOx\_AFRL). Each 4-bit bit field in the multiplexing function register corresponds to the multiplexing function selection of a GPIO port, and up to 16 input and output signal targets can logically be selected. The specific definition of GPIO multiplexing function is shown in the following table:

 $GPIOx\_AFRL[4 \times y]$ Multiplexing function  $GPIOx_AFRH[4 \times (z-8)]$ Multiplexing function 0000 **GPIO** 0000 **GPIO** 0001 AF1 0001 AF1 0010 AF2 0010 AF2 0011 AF3 0011 AF3 0100 AF4 0100 AF4 0101 AF5 0101 AF5 0110 AF6 0110 AF6 0111 AF7 0111 AF7

Table 9-1 GPIO Multiplexing function settings

#### Caution:

y, z are pin numbers: y=0~7 corresponding to GPIOx\_AFRL; z=8~15 corresponding to GPIOx\_AFRH.

The specific peripheral functions corresponding to each AF are shown in the following table:

Table 9-2 GPIO multiplexing function assignment table

| Pin  | Multiplexing function |            |           |            |            |            |            |            |
|------|-----------------------|------------|-----------|------------|------------|------------|------------|------------|
| name | AF0                   | AF1        | AF2       | AF3        | AF4        | AF5        | AF6        | AF7        |
| PA00 | GPIO                  | UART3_CTS  | UART2_CTS | RTC_TAMP   | VC1_OUT    |            | GTIM2_CH1  | GTIM2_ETR  |
| PA01 | GPIO                  | UART3_RTS  | UART2_RTS |            | LVD_OUT    |            | GTIM2_CH2  | RTC_TAMP   |
| PA02 | GPIO                  | UART3_TXD  | UART2_TXD |            | VC2_OUT    | UART3_RXD  | GTIM2_CH3  | AWT_ETR    |
| PA03 | GPIO                  | UART3_RXD  | UART2_RXD | GTIM2_CH2  | PCLK_OUT   | UART3_TXD  | GTIM2_CH4  | ATIM_CH3A  |
| PA04 | GPIO                  | MCO_OUT    | UART2_CTS |            | HCLK_OUT   | SPI_CS     | GTIM2_ETR  | ATIM_CH2A  |
| PA05 | GPIO                  | GTIM2_ETR  | UART2_RTS |            | BTIM2_TOGN | SPI_SCK    | GTIM2_CH1  | ATIM_CH1A  |
| PA06 | GPIO                  | UART2_RXD  | UART2_TXD | VC1_OUT    | BTIM2_TOGP | SPI_MISO   | GTIM1_CH1  | ATIM_BK    |
| PA07 | GPIO                  | UART2_TXD  | UART2_RXD | VC2_OUT    | BTIM1_TOGN | SPI_MOSI   | GTIM1_CH2  | ATIM_CH1B  |
| PA08 | GPIO                  | UART1_RXD  | UART1_TXD | BTIM2_TOGP | MCO_OUT    | LVD_OUT    |            | ATIM_CH1A  |
| PA09 | GPIO                  | UART3_TXD  | UART1_RXD | I2C_SCL    | BTIM1_TOGN | SPI_CS     | UART3_RXD  | ATIM_CH2A  |
| PA10 | GPIO                  | UART3_RXD  | UART1_CTS | I2C_SDA    | BTIM1_TOGP | SPI_SCK    | UART3_TXD  | ATIM_CH3A  |
| PA11 | GPIO                  | UART3_CTS  | UART1_RTS |            | VC1_OUT    | SPI_MISO   |            |            |
| PA12 | GPIO                  | UART3_RTS  | BTIM_ETR  |            | VC2_OUT    | SPI_MOSI   |            | ATIM_ETR   |
| PA13 | GPIO                  |            | I2C_SDA   | UART1_RXD  | UART2_TXD  |            | IR_OUT     |            |
| PA14 | GPIO                  | UART3_TXD  | I2C_SCL   | UART1_TXD  | UART2_RXD  |            |            |            |
| PB00 | GPIO                  | UART2_RXD  | UART1_CTS | UART2_TXD  | BTIM1_TOGP | HSIOSC_OUT | GTIM1_CH3  | ATIM_CH2B  |
| PB01 | GPIO                  | UART2_TXD  | UART1_RTS | UART2_RXD  |            | BTIM3_TOGN | GTIM1_CH4  | ATIM_CH3B  |
| PB02 | GPIO                  | UART2_CTS  | UART1_TXD | HSE_OUT    | UART1_RXD  | BTIM3_TOGP | GTIM1_ETR  | ATIM_CH1A  |
| PB07 | GPIO                  | UART3_RXD  | UART3_TXD | I2C_SDA    |            |            | GTIM1_TOGN | ATIM_CH3A  |
| PB08 | GPIO                  | I2C_SCL    | UART1_RXD | UART1_TXD  |            |            | GTIM1_CH3  | ATIM_ETR   |
| PB09 | GPIO                  | I2C_SDA    | UART1_TXD | UART1_RXD  | IR_OUT     |            | GTIM1_CH4  | ATIM_BK    |
| PB10 | GPIO                  | UART2_RTS  | UART1_RXD | I2C_SCL    | UART1_TXD  |            | GTIM2_CH3  | ATIM_CH2A  |
| PB11 | GPIO                  | LSI_OUT    |           | I2C_SDA    |            | BTIM_ETR   | GTIM2_CH4  | ATIM_CH3A  |
| PB12 | GPIO                  | GTIM2_TOGP |           | LSE_OUT    |            | SPI_CS     | GTIM1_TOGP | ATIM_BK    |
| PB14 | GPIO                  | GTIM2_CH1  |           |            |            | SPI_MISO   | RTC_OUT    | ATIM_CH2B  |
| PB15 | GPIO                  | GTIM2_CH2  |           | BTIM2_TOGN |            | SPI_MOSI   | RTC_1Hz    | ATIM_CH3B  |
| PC13 | GPIO                  | UART1_TXD  | RTC_1Hz   | UART1_CTS  | RTC_OUT    | BTIM_ETR   |            | RTC_TAMP   |
| PC14 | GPIO                  | AWT_ETR    | UART2_TXD | UART1_RTS  | BTIM2_TOGN | UART2_RXD  |            |            |
| PC15 | GPIO                  | HSE_OUT    | UART2_RXD | MCO_OUT    | BTIM2_TOGP | UART2_TXD  | UART1_RXD  |            |
| PF00 | GPIO                  | AWT_ETR    | UART3_TXD | I2C_SDA    | BTIM1_TOGN | UART3_RXD  | GTIM2_TOGP |            |
| PF01 | GPIO                  | LSE_OUT    | UART3_RXD | I2C_SCL    | BTIM1_TOGP | UART3_TXD  | GTIM2_TOGN |            |
| PF06 | GPIO                  | UART3_CTS  | I2C_SCL   |            | UART2_CTS  |            |            | BTIM3_TOGN |
| PF07 | GPIO                  | UART3_RTS  | I2C_SDA   |            | UART2_RTS  |            |            | BTIM3_TOGP |

#### 9.3.6 Interrupt Function

When each GPIO is set to digital input mode, it can be used as an external interrupt signal source, and the interrupt signal source can be set to two types: rising edge, and falling edge. Interrupt triggering methods can be used in combination, but share the same interrupt flag bit.

After the interrupt is triggered, the corresponding bit of the interrupt flag register GPIOx\_ISR will be set by hardware, and the program can determine which port generated the interrupt by querying GPIOx\_ISR. Through the interrupt flag clear register GPIOx\_ICR[y], the corresponding interrupt flag bit can be cleared.

The internal interrupt digital filter can digitally filter the input signal on the pin, providing 8 filter clock options, as shown in the following table:

GPIOx FILTER.FLTCLK Digital Filter Clock Frequency 000 HCLK / 2 001 HCLK / 4 010 HCLK/8 011 BTIM1 overflow 100 RC150K (About 150kHz) LSI (About 32.8kHz) 101 110 RC10K (About 10kHz) 111 **AWT** overflow

Table 9-3 Digital Filter Clock Selection

Due to the wide range of selected filter clock cycles, users can easily implement flexible input interrupt debounce functions. Changes in input levels that are not maintained for more than one full filter clock cycle will not be communicated through the hardware filter to the internal interrupt trigger circuitry. Changes in input levels that persist for more than two complete filter clock cycles must pass through the hardware filter.

For the edge trigger type, considering the sensitivity to the time of the trigger edge, it is recommended to disable the hardware filter function in the interrupt digital filter configuration register GPIOx\_FILTER[y], because the hardware filter can improve signal stability while also inserting certain delay.

When CW32W031 works in Sleep mode or DeepSleep mode, the external interrupt function of GPIO can still be used. When an external interrupt is generated, the chip can be woken up from Sleep mode or DeepSleep mode to Active mode.

#### Caution:

The same group of GPIOx.PINy shares a hardware filter clock source selection register, so the same group of GPIOs can only filter input signal jitter with the same filter clock.

#### 9.3.7 Other functions

#### Atomic bit operation

The GPIO controller supports bit-setting, bit-clearing and bit-flipping functions.

Writing 1 to the GPIO bit clear register GPIOx\_BSRR[y] or the bit clear register GPIOx\_BRR[y] will directly change the state of the corresponding bit of the output data register GPIOx\_ODR, thereby indirectly affecting the final output level without affecting the Status of other bits in this register.

Writing 1 to the GPIO bit toggle register GPIOx\_TOG[y] will toggle the level state of the output port.

#### Port reset state

After power-on or reset, SWCLK (PA14) and SWDIO (PA13) default to digital pull-up, BOOT (PF03) default to digital function. Other ports are analog high-resistance input by default, and pull-up or pull-down are not turned on by default.

### 9.4 Programming example

When configuring the GPIO port, you must first set SYSCTRL\_AHBEN.GPIOx to 1, enable the corresponding GPIO configuration clock and working clock.

### 9.4.1 Digital output programming example

- Step 1: Set GPIOx\_ANALOG.PINy to 0 to configure the port as a digital function;
- Step 2: Set GPIOx\_DIR.PINy to 0, configure the port as output;
- Step 3: Configure the GPIOx\_OPENDRAIN register to set the port output mode;
- **Step 4:** Configure the GPIOx\_ODR register to set the port output level.

#### 9.4.2 Digital input programming example

- Step 1: Set GPIOx\_ANALOG.PINy to 0, configure the port as a digital function;
- Step 2: Set GPIOx\_DIR.PINy to 1, configure the port as input;
- Step 3: Configure the GPIOx\_PUR register and select whether to enable the internal pull-up resistor;
- Step 4: Configure GPIOx\_PDR register, select whether to enable the internal pull-down resistor;
- Step 5: Read the GPIOx\_IDR register and read the port input level.

### 9.4.3 Analog functional programming example

**Step 1:** Set GPIOx\_ANALOG.PINy to 1 to configure the port for analog function.

#### 9.4.4 Multiplexed function programming example

- Step 1: Configure the port as digital output or digital input according to application requirements. For specific register configuration steps, please refer to section *9.4.1 Digital output programming example and section 9.4.2 Digital input programming example*;
- Step 2: Configure the GPIOx\_AFRH or GPIOx\_AFRL register to set the port multiplexing function, see *Table 9-2 GPIO multiplexing function assignment table*.



### 9.4.5 Interrupt function programming example

- Step 1: Configure the port as a digital input. For the specific register configuration steps, see section *9.4.2* Digital input programming example;
- Step 2: Configure GPIOx\_FILTER.FLTCLK, and select the port interrupt filter clock;
- Step 3: Set GPIOx\_FILTER.PINy to 1 to enable the corresponding port filter Clock;
- Step 4: Configure the NVIC controller, see chapter 5 Interrupt;
- **Step 5:** Configure the GPIOx\_RISEIE, GPIOx\_FALLIE registers according to the application requirements, and select the GPIO interrupt trigger mode;
- **Step 6:** The port interrupt input signal triggers the GPIO interrupt, execute the interrupt service function.

# 9.5 List of registers

GPIOA base address: GPIOA\_BASE = 0x4800 0000 GPIOB base address: GPIOB\_BASE = 0x4800 0400 GPIOC base address: GPIOC\_BASE = 0x4800 0800 GPIOF base address: GPIOF\_BASE = 0x4800 1400

Table 9-4 List of GPIO registers

| Register name   | Register address  | Register description                                  |
|-----------------|-------------------|-------------------------------------------------------|
| GPIOx_DIR       | GPIOx_BASE + 0x00 | GPIOx I/O direction register                          |
| GPIOx_OPENDRAIN | GPIOx_BASE + 0x04 | GPIOx output mode register                            |
| GPIOx_PDR       | GPIOx_BASE + 0x0C | GPIOx pull-down Resistor Register                     |
| GPIOx_PUR       | GPIOx_BASE + 0x10 | GPIOx pull-up Resistor Register                       |
| GPIOx_AFRH      | GPIOx_BASE + 0x14 | GPIOx Multiplexing function register high segment     |
| GPIOx_AFRL      | GPIOx_BASE + 0x18 | GPIOx Multiplexing function register low segment      |
| GPIOx_ANALOG    | GPIOx_BASE + 0x1C | GPIOx Analog Digital Configuration Register           |
| GPIOx_RISEIE    | GPIOx_BASE + 0x24 | GPIOx Rising edge interrupt enable register           |
| GPIOx_FALLIE    | GPIOx_BASE + 0x28 | GPIOx Falling edge interrupt enable register          |
| GPIOx_ISR       | GPIOx_BASE + 0x34 | GPIOx Interrupt flag register                         |
| GPIOx_ICR       | GPIOx_BASE + 0x38 | GPIOx Interrupt flag clear register                   |
| GPIOx_FILTER    | GPIOx_BASE + 0x40 | GPIOx Interrupt digital filter configuration register |
| GPIOx_IDR       | GPIOx_BASE + 0x50 | GPIOx input data register                             |
| GPIOx_ODR       | GPIOx_BASE + 0x54 | GPIOx output data register                            |
| GPIOx_BRR       | GPIOx_BASE + 0x58 | GPIOx bit clear register                              |
| GPIOx_BSRR      | GPIOx_BASE + 0x5C | GPIOx bit-setting clear register                      |
| GPIOx_TOG       | GPIOx_BASE + 0x60 | GPIOx bit flip register                               |

# 9.6 Register description

See section 1 Documentation conventions for abbreviations used in register descriptions.

# 9.6.1 GPIOx\_DIR GPIO I/O direction register (x = A, B, C, F)

Address offset: 0x00 Reset value: 0x0000 FFFF(GPIOA)

0x0000 FFFF(GPIOB) 0x0000 E000(GPIOC)

0x0000 00CB(GPIOF)

| Bit field | Name             | Permission | Function description                                                                                   |
|-----------|------------------|------------|--------------------------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                                           |
| 15:0      | PINy<br>y=0 ~ 15 | RW         | Port input and output direction control 0: Configure the port as output 1: Configure the port as input |

# 9.6.2 GPIOx\_OPENDRAIN GPIO output mode register ( x = A, B, C, F )

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name             | Permission | Function description                                                  |
|-----------|------------------|------------|-----------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                          |
| 15:0      | PINy<br>y=0 ~ 15 | RW         | Port output mode control bit 0: Push-pull output 1: Open-drain output |

# 9.6.3 GPIOx\_PDR GPIO Pull-down resistor register (x = A, B, C, F)

Address offset: 0x0C Reset value: 0x0000 0000(GPIOA)

0x0000 0000(GPIOB)

0x0000 0000(GPIOC)

0x0000 0008(GPIOF)

| Bit field | Name             | Permission | Function description                                                                                                                                                                                                                 |
|-----------|------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                                                                                                                                                                         |
| 15:0      | PINy<br>y=0 ~ 15 | RW         | Port pull-down resistor enable control 0: Disable pull-down resistors 1: Enable pull-down resistors Caution: When GPIOx_PDR.PINy and GPIOx_PUR.PINy are set to 1 at the same time, the port state is to enable the pull-up resistor. |

### 9.6.4 GPIOx\_PUR GPIO Pull-up resistor register (x = A, B, C, F)

Address offset: 0x10 Reset value: 0x0000 0000

| Bit field | Name             | Permission | Function description                                                                                                                                                                                                           |
|-----------|------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                                                                                                                                                                   |
| 15:0      | PINy<br>y=0 ~ 15 | RW         | Port pull-up resistor enable control 0: Disable pull-up resistors 1: Enable pull-up resistors Caution: When GPIOx_PDR.PINy and GPIOx_PUR.PINy are set to 1 at the same time, the port state is to enable the pull-up resistor. |

# 9.6.5 GPIOx\_AFRH GPIO Multiplexing function register high segment (x = A, B, C, F)

Address offset: 0x14 Reset value: 0x0000 0000

| Bit field                                                       | Name               | Permission | Function description                                                                                                        |
|-----------------------------------------------------------------|--------------------|------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:28<br>27:24<br>23:20<br>19:16<br>15:12<br>11:8<br>7:4<br>3:0 | AFRy<br>y = 8 ~ 15 | RW         | Port digital multiplexing function control 0000: GPIO 0001: AF1 0010: AF2 0011: AF3 0100: AF4 0101: AF5 0110: AF6 0111: AF7 |

### 9.6.6 GPIOx\_AFRL GPIO Multiplexing function register low segment (x = A, B, C, F)

Address offset: 0x18 Reset value: 0x0000 0000

| Bit field                                                       | Name              | Permission | Function description                                                                                                        |
|-----------------------------------------------------------------|-------------------|------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:28<br>27:24<br>23:20<br>19:16<br>15:12<br>11:8<br>7:4<br>3:0 | AFRy<br>y = 0 ~ 7 | RW         | Port digital multiplexing function control 0000: GPIO 0001: AF1 0010: AF2 0011: AF3 0100: AF4 0101: AF5 0110: AF6 0111: AF7 |

# 9.6.7 GPIOx\_ANALOG GPIO Analog Digital Configuration Register (x = A, B, C, F)

Address offset: 0x1C Reset value: 0x0000 9FFF(GPIOA)

0x0000 FFFF(GPIOB)

0x0000 E000(GPIOC)

0x0000 00C3(GPIOF)

| Bit field | Name             | Permission | Function description                                                                                                               |
|-----------|------------------|------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                                                                       |
| 15:0      | PINy<br>y=0 ~ 15 | RW         | Port analog/digital function configuration 0: Configure the port as a digital function 1: Configure the port as an analog function |



# 9.6.8 GPIOx\_RISEIE GPIO Rising edge interrupt enable register (x = A, B, C, F)

Address offset: 0x24 Reset value: 0x0000 0000

| Bit field | Name             | Permission | Function description                                                                                                                                                   |
|-----------|------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                                                                                                           |
| 15:0      | PINy<br>y=0 ~ 15 | RW         | Port rising edge interrupt enable control 0: Disable the rising edge interrupt of the corresponding port 1: Enable the rising edge interrupt of the corresponding port |

# 9.6.9 GPIOx\_FALLIE GPIO Falling edge interrupt enable register (x = A, B, C, F)

Address offset: 0x28 Reset value: 0x0000 0000

| Bit field | Name             | Permission | Function description                                                                                                                                                        |
|-----------|------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                                                                                                                |
| 15:0      | PINy<br>y=0 ~ 15 | RW         | Port falling edge interrupt enable control  0: Disable the falling edge interrupt of the corresponding port  1: Enable the falling edge interrupt of the corresponding port |

# 9.6.10 GPIOx\_ISR GPIO Interrupt flag register (x = A, B, C, F)

Address offset: 0x34 Reset value: 0x0000 0000

| Bit field | Name             | Permission | Function description                                                                                  |
|-----------|------------------|------------|-------------------------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                                          |
| 15:0      | PINy<br>y=0 ~ 15 | RO         | Port interrupt status flag  0: Enabled interrupt not detected  1: Enabled interrupt has been detected |



# 9.6.11 GPIOx\_ICR GPIO Interrupt flag clear register (x = A, B, C, F)

Address offset: 0x38 Reset value: 0x0000 FFFF(GPIOA)

0x0000 FFFF(GPIOB)

0x0000 E000(GPIOC)

0x0000 00CB(GPIOF)

| Bit field | Name             | Permission | Function description                                                                                  |
|-----------|------------------|------------|-------------------------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                                          |
| 15:0      | PINy<br>y=0 ~ 15 | R1W0       | Port interrupt status flag clear<br>W0: Clear the corresponding interrupt flag bit<br>W1: No function |

# 9.6.12 GPIOx\_FILTER GPIO Interrupt digital filter configuration register (x = A, B, C, F)

Address offset: 0x40 Reset value: 0x0000 0000

| Bit field | Name             | Permission | Function description                                                                                                                                                                                                     |
|-----------|------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19     | RFU              | -          | Reserved bits, please keep the default value                                                                                                                                                                             |
| 18:16     | FLTCLK           | RW         | Port interrupt filter clock selection 000: HCLK / 2 001: HCLK / 4 010: HCLK / 8 011: BTIM1 overflow 100: RC150K (About 150KHz) 101: LSI (About 32.8KHz) 110: RC10K (About 10KHz) 111: AWT overflow                       |
| 15:0      | PINy<br>y=0 ~ 15 | RW         | Port filter clock enable control  0: Disable the corresponding port to filter the clock  1: Enable the corresponding port to filter the clock  Caution: Filter out pulses with a width less than the  FLTCLK clock width |

# 9.6.13 GPIOx\_IDR GPIO input data register (x = A, B, C, F)

Address offset: 0x50 Reset value: 0x0000 6000(GPIOA)

0x0000 0000(GPIOB)

0x0000 0000(GPIOC)

0x0000 0000(GPIOF)

| Bit field | Name             | Permission | Function description                                                            |
|-----------|------------------|------------|---------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                    |
| 15:0      | PINy<br>y=0 ~ 15 | RO         | Read port input level status 0: The port is low level 1: The port is high level |

### 9.6.14 GPIOx\_ODR GPIO output data register (x = A, B, C, F)

Address offset: 0x54 Reset value: 0x----

| Bit field | Name             | Permission | Function description                                                                 |
|-----------|------------------|------------|--------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                         |
| 15:0      | PINy<br>y=0 ~ 15 | RW         | Set the port output level 0: Set port output low level 1: Set port output high level |

# 9.6.15 GPIOx\_BRR GPIO port bit set clear register (x = A, B, C, F)

Address offset: 0x58 Reset value: 0x0000 0000

| Bit field | Name             | Permission | Function description                                                                                                                                    |
|-----------|------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                                                                                            |
| 15:0      | BRRy<br>y=0 ~ 15 | R0W1       | Port bit clear control 0: Does not affect the corresponding bits of the GPIOx_ ODR register 1: Set the corresponding bit of the GPIOx_ODR register to 0 |

# 9.6.16 GPIOx\_BSRR GPIO port bit-setting clear register (x = A, B, C, F)

Address offset: 0x5C Reset value: 0x0000 0000

| Bit field | Name             | Permission | Function description                                                                                                                                                                                                           |
|-----------|------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | BRRy<br>y=0 ~ 15 | R0W1       | Port bit-setting clear control 0: Does not affect the corresponding bits of the GPIOx_ ODR register 1: Set the corresponding bit of the GPIOx_ODR register to 0                                                                |
| 15:0      | BSSy<br>y=0 ~ 15 | R0W1       | Port bit-setting control 0: Does not affect the corresponding bits of the GPIOx_ ODR register 1: Set the corresponding bit of the GPIOx_ODR register to 1 Caution: When BRRy and BSSy are both set 1, BSSy has higher priority |

# 9.6.17 GPIOx\_TOG GPIO Port Bit Flip Register (x = A, B, C, F)

Address offset: 0x60 Reset value: 0x0000 0000

| Bit field | Name             | Permission | Function description                                                                                                                                 |
|-----------|------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU              | -          | Reserved bits, please keep the default value                                                                                                         |
| 15:0      | PINy<br>y=0 ~ 15 | R0W1       | Port Bit Flip Control 0: Does not affect the corresponding bits of the GPIOx_ ODR register 1: Invert the corresponding bit of the GPIOx_ODR register |

# 10 Cyclic redundancy check (CRC)

### 10.1 Overview

Cyclic Redundancy Check (CRC) is mainly used to verify the correctness and integrity of data transmission or data storage. The CW32W031 integrates a CRC calculation unit, which supports the use of multiple CRC algorithms to perform CRC calculation on the input data.

#### 10.2 Main features

- 8bit input data bit width
- Two kinds of polynomials
   CRC-16 polynomial 1: x<sup>16</sup> + x<sup>15</sup> + x<sup>2</sup> + 1
   CRC-16 polynomial 2: x<sup>16</sup> + x<sup>12</sup> + x<sup>5</sup> + 1
- Eight kinds of commonly used algorithms

  Combination based on polynomial, initial value, result XOR value, input/output inversion



# 10.3 Functional description

The CRC unit obtains the CRC calculation result by performing a 'division' operation on the input data (or the inversion of the input data) and the selected polynomial value, and then inverting or not inverting the obtained remainder, as well as XOR processing.

Before the CRC unit is used, it is necessary to set SYSCTRL\_AHBEN.CRC to 1, and turn on the configuration clock and working clock of the CRC unit, which are generally set during system initialization.

### 10.3.1 Algorithmic modes

The CRC unit of CW32W031 supports multiple algorithm modes. Different CRC algorithms have different parameters such as polynomial, initial value, input data inversion, output data inversion, and result XOR value, as shown in the following table:

Table 10-1 CRC algorithm modes

| Algorithm name    | Polynomial<br>value | Initial value | Input<br>inversion | Output inversion | Result XOR<br>value |
|-------------------|---------------------|---------------|--------------------|------------------|---------------------|
| CRC16_IBM         | 0x8005              | 0x0000        | True               | True             | 0x0000              |
| CRC16_MAXIM       | 0x8005              | 0x0000        | True               | True             | 0xFFFF              |
| CRC16_USB         | 0x8005              | 0xFFFF        | True               | True             | 0xFFFF              |
| CRC16_MODBUS      | 0x8005              | 0xFFFF        | True               | True             | 0x0000              |
| CRC16_CCITT       | 0x1021              | 0x0000        | True               | True             | 0x0000              |
| CRC16_CCITT_False | 0x1021              | 0xFFFF        | False              | False            | 0x0000              |
| CRC16_X25         | 0x1021              | 0xFFFF        | True               | True             | 0xFFFF              |
| CRC16_XMODEM      | 0x1021              | 0x0000        | False              | False            | 0x0000              |

The meaning of each parameter is as follows:

Polynomial value

The polynomial is the description of the code group, such as CRC-16 polynomial 2:  $x^{16} + x^{12} + x^5 + 1$ , the corresponding code group is 1 0001 0000 0010 0001. Because the highest bit of the polynomial code group is fixed to 1, and the position of the highest bit is known, the code group after removing the highest bit 1 is generally called a polynomial value. For example, the value of CRC-16 polynomial 2 is 0001 0000 0010 0001, that is 0x1021.

Initial value

The initial value of the CRC register before calculating the CRC check value.

Input data inversion

That is, before the calculation starts, the high and low order bits of the data that need to calculate the CRC check value are reversed, such as the data bit 1011, which is 1101 after the inversion.

Output data inversion

After the CRC calculation is completed, before the XOR value is performed with the result, the high and low order bits of the calculated value are reversed. If the calculation result is 1011, it will be 1101 after inversion.

Result XOR value

After the CRC calculation is completed, the obtained CRC calculation value is XORed with the result XOR value to obtain the final CRC check value.

#### 10.3.2 Input data bit width

The CRC calculation unit supports 8bit input data bit width. When inputting data, input the low byte first and then the high byte.

For example, the user needs to calculate the CRC check value of the group of data 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, and the writing sequence is 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77

Code example:

CW\_CRC -> DR = 0x00; CW\_CRC -> DR = 0x11; CW\_CRC -> DR = 0x22; CW\_CRC -> DR = 0x33; CW\_CRC -> DR = 0x44; CW\_CRC -> DR = 0x55; CW\_CRC -> DR = 0x66; CW\_CRC -> DR = 0x77;



# 10.4 Programming examples

### 10.4.1 CRC16\_CCITT algorithm mode

- Step 1: Set CRC\_CR.MODE to 0x04, select the CRC16\_CCITT algorithm mode, and the initial value of the CRC register is automatically configured by hardware to 0x0000;
- Step 2: Write the raw data to be encoded into the data register CRC\_DR in turn, and the input data bit width can be selected from 8bit, 16bit, and 32bit. See the code example in section 10.3.2 Input data bit width;
- Step 3: Read CRC\_RESULT to get the CRC check value.

Code example:

tempdata = CW\_CRC -> RESULT;

# 10.5 List of registers

CRC base address: CRC\_BASE =0x4002 3000

Table 10-2 List of CRC registers

| Register name | Register address | Register description |
|---------------|------------------|----------------------|
| CRC_CR        | CRC_BASE + 0x00  | Control register     |
| CRC_DR        | CRC_BASE + 0x08  | Data register        |
| CRC_RESULT    | CRC_BASE + 0x0C  | Result register      |

# 10.6 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

# 10.6.1 CRC\_CR control register

Address offset: 0x00 Reset value: 0x0000 0004

| Bit field | Name | Permission | Function description                                                                                                                                                               |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                       |
| 3:0       | MODE | RW         | CRC algorithm mode configuration 0000: CRC16_IBM 0001: CRC16_MAXIM 0010: CRC16_USB 0011: CRC16_MODBUS 0100: CRC16_CCITT 0101: CRC16_CCITT_False 0110: CRC16_X25 0111: CRC16_XMODEM |

# 10.6.2 CRC\_DR data register

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:8      | RFU  | -          | Reserved bits, please keep the default value |
| 7:0       | DR   | RW         | Data write register, bit width 8bit          |

# 10.6.3 CRC\_RESULT result register

Address offset: 0x0C Reset value: 0x0000 FFFF

| Bit field | Name   | Permission | Function description                         |
|-----------|--------|------------|----------------------------------------------|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value |
| 15:0      | RESULT | RO         | CRC calculation result                       |



# 11 Automatic wake-up timer (AWT)

### 11.1 Overview

CW32W031 integrates one automatic wake-up timer (AWT), AWT contains a 16bit down counter and is driven by a programmable prescaler. AWT can choose five kinds of counting clock sources, can work in timing mode or counting mode. When the counter clock source is LSE or LSI, the AWT can keep running in DeepSleep mode, and the underflow interrupt can wake up the MCU back to Active mode.

#### 11.2 Main features

- 16bit down counter
- 5 kinds of working clock source: LSE/HSE/LSI/HSIOSC/ETR
- Programmable prescaler: 2~32768 frequency division
- Supports to keep running in DeepSleep mode, interrupt wake-up MCU
- When the counting clock source is LSI, the wake-up period is 60μs~65536s

# 11.3 Functional description

#### 11.3.1 Functional block diagram

The functional block diagram of AWT is shown in the following figure:

AWT\_CR.SRC

AWT\_CR.PRS

LSE

HSE

LSI

HSIOSC

ARR

CNT

16bit

UD

Figure 11-1 AWT functional block diagram

#### Clock source

The counter clock of AWT can be selected from 5 clock sources RCLK: LSE/HSE/LSI/HSIOSC and the ETR signal input by the external AWT\_ETR pin, which is selected by the SRC bit field of the control register AWT\_CR. The clock source is divided by the prescaler as the counter clock of the AWT.

#### Caution:

The clock source selection must be completed before starting the timer, and modification is prohibited during the running process of the timer, otherwise the AWT will work abnormally.

#### Prescaler

AWT has a built-in 4-bit prescaler, and the counter clock source RCLK is divided by the prescaler to drive the counter to count. The specific frequency division coefficient is selected through the PRS bit field of the control register AWT\_CR. The corresponding relationship between the setting value and the frequency division coefficient is shown in the following table:

| PRS  | Frequency<br>division<br>coefficient | PRS  | Frequency<br>division<br>coefficient | PRS  | Frequency<br>division<br>coefficient | PRS  | Frequency<br>division<br>coefficient |
|------|--------------------------------------|------|--------------------------------------|------|--------------------------------------|------|--------------------------------------|
| 0x00 | Reserve, not configurable            | 0x04 | 16                                   | 0x08 | 256                                  | 0x0C | 4096                                 |
| 0x01 | 2                                    | 0x05 | 32                                   | 0x09 | 512                                  | 0x0D | 8192                                 |
| 0x02 | 4                                    | 0x06 | 64                                   | 0x0A | 1024                                 | 0x0E | 16384                                |
| 0x03 | 8                                    | 0x07 | 128                                  | 0x0B | 2048                                 | 0x0F | 32768                                |

Table 11-1 AWT counting clock prescaler coefficient

### Caution:

The setting of the prescaler coefficient must be completed before starting the timer, and it is forbidden to modify it during the running process of the timer, otherwise the AWT will work abnormally.



#### **Counting unit**

The core component of the counting unit is a 16bit down counter CNT and a 16bit automatic reload register ARR.

The reload register ARR is used to set the timing or counting period, and the number of timing or counting periods is ARR+1. The counter CNT is used to count down, underflow after decrementing to 0, and start counting again from the reload value ARR.

Set AWT\_CR.EN to 1 to enable AWT, and the counter CNT starts to count down from the reload value ARR under the drive of the counting clock TCLK. When it decrements to 0, an underflow occurs, and the underflow interrupt flag bit AWT\_ISR.UD will be set by hardware, the counter CNT reloads the value of the AWT\_ARR register and restarts the countdown of the next cycle.

The user can set the value of the reload value register AWT\_ARR at any time, but it does not affect the current count value of CNT, and the newly set value will take effect in the next timing or counting cycle.

The AWT count timing diagram is shown in the following figure:



Figure 11-2 AWT counting and interrupt flags

#### 11.3.2 Timing function

The AWT timing function is generally used to delay or generate time base signals at fixed intervals. HSE/HSIOSC/LSE/LSI/ETR can be used as its clock source. When selecting ETR as its clock source, it is necessary to ensure that the signal input by ETR is a fixed period signal. The functional block diagram of AWT timing mode is shown in the following figure:

AWT\_CR.SRC

AWT\_CR.PRS

LSE

HSE

LSI

HSIOSC

ARR

CNT
16bit

UD

Figure 11-3 Timing function block diagram

Timing time T calculation formula:

$$T = (2^{PRS}/RCLK) \times (ARR + 1)$$

Among them, RCLK is the counter clock source, PRS is the prescaler coefficient, and ARR is the reload value.

### Example:

When the counter clock source RCLK is LSE (the clock frequency is 32768Hz), the timing is required to be 200ms.

If the prescaler coefficient PRS is set to 0x01, calculate

$$T = 200 \text{ ms} = (2^1/32768) \times (ARR + 1)$$

that

ARR=3275.8, the nearest integer is: 3276 (0xCCC)

That is, it is necessary to set the reload value ARR to 0xCCC.

Set the timer enable control bit AWT\_CR.EN to 1, and the reload value ARR is loaded into the counter CNT. After that, every time a TCLK clock comes, the CNT count value is decremented by 1. When the count value is decremented to 0, an underflow occurs, and the underflow interrupt flag AWT\_ISR.UD is set by hardware. If the interrupt is enabled (set AWT\_IER.UD to 1), the CPU will respond to the interrupt service routine. Before exiting the interrupt service routine, AWT\_ICR.UD should be set to 0 to clear this flag to avoid repeatedly entering the interrupt service routine.

The timing function configuration process is as follows (when the selected clock source is LSE/HSE/LSI/HSIOSC, steps 1 and 2 do not need to be performed):

- Step 1: Set the relevant bit of the peripheral clock enable control register SYSCTRL\_AHBEN to 1, and enable the configuration clock and working clock of the GPIO port corresponding to AWT\_ETR;
- Step 2: Set the relevant bits of the GPIO multiplexed function registers GPIOx\_AFRH and GPIOx\_AFRL, and configure the corresponding pin to be the AWT\_ETR function of the AWT timer;
- Step 3: Set the peripheral clock enable control register SYSCTRL\_APBEN2.AWT to 1, and turn on the configuration clock of the AWT module;
- Step 4: Configure the control register AWT\_CR.SRC and select the AWT count clock source;
- Step 5: Configure the control register AWT\_CR.PRS and select the frequency division coefficient of the AWT count clock;
- Step 6: Set the interrupt enable register AWT\_IER.UD to 1 to enable the counter CNT underflow event to trigger an interrupt request;
- Step 7: Configure the reload value register AWT\_ARR, and set the timing period. For the specific configuration, please refer to the relevant description in this section;
- Step 8: Set the control register AWT\_CR.EN to 1, and start the timer to start timing;
- Step 9: The counter CNT overflows, enters the interrupt service function, and sets AWT\_ICR.UD to 0 to clear the interrupt flag;
- **Step 10:** If you do not want to continue timing, set the control register AWT\_CR.EN to 0 to disable the timer timing function.

#### 11.3.3 Count function

The AWT count function is used to measure the number of times an event occurs. In the counting mode, ETR is selected as the counting clock source, and the user inputs the external signal that needs to be counted through the AWT\_ETR pin (for specific pins, please refer to the pin definition in the datasheet). The functional block diagram of AWT counting mode is shown in the following figure:

AWT\_CR.SRC

AWT\_CR.PRS

RCLK

/2,.../32768

TCLK

CNT
16bit

UD

Figure 11-4 Count function block diagram

The counting clock source is selected by AWT\_CR.SRC, the prescaler coefficient is selected by AWT\_CR.PRS, and the counting period is configured by AWT\_ARR.ARR, and the counting period is AWT\_ARR+1.

Set the timer enable control bit AWT\_CR.EN to 1, and the reload value ARR is loaded into the counter CNT. After that, every time a TCLK clock comes, the CNT count value is decremented by 1. When the count value is decremented to 0, an underflow occurs, and the underflow interrupt flag AWT\_ISR.UD is set by hardware. If the interrupt is enabled (set AWT\_IER.UD to 1), the CPU will respond to the interrupt service routine. Before exiting the interrupt service routine, AWT\_ICR.UD should be set to 0 to clear this flag to avoid repeatedly entering the interrupt service routine.

The configuration process of count function is as follows:

- Step 1: Set the relevant bit of the peripheral clock enable control register SYSCTRL\_AHBEN to 1, and enable the configuration clock and working clock of the GPIO port corresponding to AWT\_ETR;
- Step 2: Set the relevant bits of the GPIO multiplexed function registers GPIOx\_AFRH and GPIOx\_AFRL, and configure the corresponding pin to be the AWT\_ETR function of the AWT timer;
- Step 3: Set the peripheral clock enable control register SYSCTRL\_APBEN2.AWT to 1, and turn on the configuration clock of the AWT module;
- Step 4: Set the control register AWT\_CR.SRC to 0x04, and select the AWT count clock source as ETR;
- Step 5: Configure the control register AWT\_CR.PRS and select the frequency division coefficient of the AWT count clock;
- **Step 6:** Set the interrupt enable register AWT\_IER.UD to 1 to enable the counter CNT underflow event to trigger an interrupt request;
- Step 7: According to the number N to be counted, set the value of the reload value register AWT\_ARR to N-1;
- Step 8: Set the control register AWT\_CR.EN to 1, and start the counter to start counting;
- **Step 9:** The counter CNT overflows, enters the interrupt service function, and sets AWT\_ICR.UD to 0 to clear the interrupt flag;
- Step 10: If you do not want to continue counting, set the AWT control register AWT\_CR.EN to 0 to disable the counter counting function.



173 / 572 Rev 1.0

### 11.4 Low power mode

When the counter clock source is LSE or LSI, the AWT can keep running in DeepSleep mode, and the underflow interrupt can wake up the MCU back to Active mode.

When selecting LSE (32.768KHz) or LSI (32.8KHz) as the counter clock source, set the prescaler coefficient AWT\_CR.PRS to 0x01 and the reload value AWT\_ARR to 0, then the shortest timing period is 60µs; Set the prescaler coefficient AWT\_CR.PRS to 0x0F, and the reload value AWT\_ARR to 0xFFFF, so the longest timing period is 65536s.

Therefore, in low-power timing mode, the wake-up period can be configured from 60µs ~ 65536s.

# 11.5 AWT interrupts

When the value of the 16-bit counter CNT decrements to 0, an underflow occurs, and the underflow interrupt flag bit AWT\_ISR.UD will be set by hardware. If the interrupt is enabled (the interrupt enable bit AWT\_IER.UD is set to 1), the CPU will respond to the interrupt service routine. Before exiting the interrupt service routine, the interrupt flag clear register AWT\_ICR.UD should be set to 0 to clear the flag bit to avoid repeated entry into the interrupt service program.

When LSE or LSI is selected as the AWT working clock source, the AWT can continue to work in DeepSleep mode, and the AWT interrupt can wake up the MCU to Active mode.

# 11.6 Debugging support

AWT supports stop or continue counting in debug mode, which is set by the AWT bit field of the debug status timer control register SYSCTRL\_DEBUG.

Set SYSCTRL\_DEBUG.AWT to 1, then suspend the AWT counter counting in the debug state;

Set SYSCTRL\_DEBUG.AWT to 0, then the AWT counter continues to count in the debug state.

In the debug state, the program stops running. If the counting of the AWT counter is not stopped, the AWT\_ISR. UD interrupt flag will be generated soon, which will cause the program to jump to the interrupt service routine and affect the debugging of other functions. It is recommended to enable the AWT counter to stop counting function in debug mode.

# 11.7 List of registers

AWT base address: AWT\_BASE = 0x4001 4C00

Table 11-2 List of AWT registers

| Register name | Register address | Register description          |
|---------------|------------------|-------------------------------|
| AWT_CR        | AWT_BASE + 0x00  | Control register              |
| AWT_ARR       | AWT_BASE + 0x04  | Reload value register         |
| AWT_CNT       | AWT_BASE + 0x08  | Count value register          |
| AWT_IER       | AWT_BASE + 0x10  | Interrupt enable register     |
| AWT_ISR       | AWT_BASE + 0x14  | Interrupt flag register       |
| AWT_ICR       | AWT_BASE + 0x1C  | Interrupt flag clear register |

# 11.8 Register descriptions

See section  ${\it 1}$  Documentation conventions for abbreviations used in register descriptions.

# 11.8.1 AWT\_CR control register

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                              |  |  |
|-----------|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:11     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                              |  |  |
| 10:8      | SRC  | RW         | Counting clock source selection 000: HSIOSC 001: LSI 010: HSE 011: LSE 100: ETR Caution: When the clock source is LSI/LSE, the timer can work in DeepSleep mode.                                                                                                         |                                                                                                                                                                                                                                                              |  |  |
| 7:4       | PRS  | RW         | Counting clock prescaler configuration 0000: reserved, not configurable 0001: 2 frequency division 0010: 4 frequency division 0011: 8 frequency division 0100: 16frequency division 0101: 32 frequency division 0110: 64 frequency division 0111: 128 frequency division | tion  1000: 256 frequency division  1001: 512 frequency division  1010: 1024 frequency division  1011: 2048 frequency division  1100: 4096 frequency division  1101: 8192 frequency division  1110: 16384 frequency division  1111: 32768 frequency division |  |  |
| 3         | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                              |  |  |
| 2:1       | MD   | RW         | Please write 11                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                              |  |  |
| 0         | EN   | RW         | Timer enable control 0: Disabled 1: Enabled Caution: The EN bit field can be set to 1 only after the configuration of AWT_CR[10:1] is completed.                                                                                                                         |                                                                                                                                                                                                                                                              |  |  |

# 11.8.2 AWT\_ARR reload value register

Address offset: 0x04 Reset value: 0x0000 FFFF

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | ARR  | RW         | Counter reload value                         |

# 11.8.3 AWT\_CNT count value register

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | CNT  | RO         | Counter count value                          |

### 11.8.4 AWT\_IER interrupt enable register

Address offset: 0x10 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                    |
|-----------|------|------------|-------------------------------------------------------------------------|
| 31:4      | RFU  | -          | Reserved bits, please keep the default value                            |
| 3         | UD   | RW         | Counter underflow interrupt enable configuration 0: Disabled 1: Enabled |
| 2:0       | RFU  | -          | Reserved bits, please keep the default value                            |

# 11.8.5 AWT\_ISR interrupt flag register

Address offset: 0x14 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                         |
|-----------|------|------------|----------------------------------------------------------------------------------------------|
| 31:4      | RFU  | -          | Reserved bits, please keep the default value                                                 |
| 3         | UD   | RO         | Counter underflow interrupt flag 0: The timer has not overflowed 1: The timer has overflowed |
| 2:0       | RFU  | -          | Reserved bits, please keep the default value                                                 |



# 11.8.6 AWT\_ICR interrupt flag clear register

Address offset: 0x1C Reset value: 0x0000 003F

| Bit field | Name | Permission | Function description                                                                 |
|-----------|------|------------|--------------------------------------------------------------------------------------|
| 31:4      | RFU  | -          | Reserved bits, please keep the default value                                         |
| 3         | UD   | R1W0       | Counter underflow interrupt flag clear<br>W0: Clear overflow flag<br>W1: No function |
| 2:0       | RFU  | -          | Reserved bits, please keep the default value                                         |

# 12 Real time clock (RTC)

#### 12.1 Overview

The Real time clock (RTC) is a dedicated counter/timer that provides calendar information including hours, minutes, seconds, day, month, year, and week.

RTC has two independent alarm clocks, the time and date can be set in combination, and the alarm clock interrupt can be generated and output through the pin; it supports the time stamp function, which can be triggered by the pin, record the current date and time, and generate a time stamp interrupt at the same time; Support periodic interrupt; support automatic wake-up function, which can generate interrupts and output through pins; support 1Hz square wave and RTCOUT output functions; support internal clock calibration compensation.

The CW32W031 has a built-in independently calibrated RC clock source with a frequency of 32KHz to provide the drive clock for the RTC. The RTC can run in DeepSleep mode and is suitable for applications requiring low power consumption.

#### 12.2 Main features

- Calendar function (BCD code format)
  - Seconds, minutes, hours (support 12/24 time system)
  - Week, day, month and year, support automatic leap year correction
- Interrupt function
  - Alarm clock A, B interrupt, can be output through pin
  - Cycle interruption, wide range: 0.5s to 1 month
  - Automatic wake-up interrupt, range: 61µs ~ 145h, can be output through pins
  - Timestamp interruption
- Calibration compensation function
  - Minimum clock error compensation step size, 0.119ppm
  - 1Hz square wave output pin
- Register lock protection to prevent accidental modification
- Operates in Active mode, Sleep mode, and DeepSleep mode

## 12.3 Functional description

### 12.3.1 Functional block diagram

The functional block diagram of the real-time clock (RTC) is shown in the following figure:

CR2.AWTSRC Auto wakeup reload value ARR RTCCLK/2 RTCCLK/4 RTCCLK/8 RTCCLK/16 Automatic wake-up ISR.AWTIMER Automatic Wakeup RTC1Hz frequency divider wake-up timer interrupt RTC1Hz/2 IER.AWTIMER RTC1Hz/4 CR0.RTC1HZ RTC1Hz/8 PCLK High frequency RTC\_1Hz compensation circuit 2 frequency division CR2.RTCOUT Compensation register CR1.SOURCE CR0.INTERVAL RTC\_OUT Low frequency 0.5s LSE compensation circuit 1s LSI Calendar counter 1min HSE/128 ISR.INTERVAL RTCCLK RTC2Hz [seconds, minutes, hours] Periodic Divider 1h HSE/256 [year, month, day, week] interrupt 1 day HSE/512 IER.INTERVAL 1month HSE/1024 ISR.ALARMA Alarm A is Alarm A register interrupted IER.ALARMA CR2.TAMPEDGE ISR. ALARMAB Alarm B register Alarm B is interrupted RTC\_TAMP Edge detection IER. ALARMB ISR.TAMP Timestamp Timestamp date, time register breaks IER.TAMP

Figure 12-1 RTC functional block diagram

#### 12.3.2 Functional overview

The real-time clock (RTC) is mainly composed of a dedicated high-precision RTC timer. The clock source can be selected from the external low-speed clock LSE or the internal low-speed clock LSI. When the external high-speed clock HSE is selected, it can only be used for general timing/counter.

The time register RTC\_TIME and the date register RTC\_DATE respectively record the current time and date value in BCD code format, and will automatically check the validity when writing them, any illegal time or date value will not be written, such as the 32 days, 2A hours, 61 seconds, 13 months, etc.

In the date register RTC\_DATE, the YEAR bit field represents the year, the valid value is 0 to 99; the MONTH bit field represents the month, the valid value is 1 to 12; the DAY bit field represents the day, the valid value is 1 to 31; the WEEK bit field represents the week, the valid value is 0 ~6, where 0 means Sunday and 1 to 6 means Monday to Saturday.

In the time register RTC\_TIME, the SECOND bit field represents seconds, with a valid value of 0 to 59; the MINUTE bit field represents minutes, with a valid value of 0 to 59; the HOUR bit field represents hours, with a valid value of 1 to 12 or 0 to 23, and 12 hours can be selected. system or 24-hour format. The H24 bit field of the control register RTC\_CR0 selects 12 or 24 hours:

- When H24 is '1', select 24-hour clock
- When H24 is '0', 12 o'clock is selected, and the highest bit of the HOUR bit field represents AM/PM:
  - '0' means AM
  - '1' means PM

The HOUR bit field value is detailed in the following table:

Table 12-1 HOUR bit field values in 12/24 time system

| 12 tir       | ne system (       | (RTC_CR0.H24=0 | 0)                | 24 time system (RTC_CR0.H24=1) |                |            |                   |
|--------------|-------------------|----------------|-------------------|--------------------------------|----------------|------------|-------------------|
| Time         | HOUR<br>bit field | Time           | HOUR<br>bit field | Time                           | HOUR bit field | Time       | HOUR<br>bit field |
| AM12 o'clock | 0x12              | PM12 o'clock   | 0x32              | 00 o'clock                     | 0x00           | 12 o'clock | 0x12              |
| AM1 o'clock  | 0x01              | PM1 o'clock    | 0x21              | 01 o'clock                     | 0x01           | 13 o'clock | 0x13              |
| AM2 o'clock  | 0x02              | PM2 o'clock    | 0x22              | 02 o'clock                     | 0x02           | 14 o'clock | 0x14              |
| AM3 o'clock  | 0x03              | PM3 o'clock    | 0x23              | 03 o'clock                     | 0x03           | 15 o'clock | 0x15              |
| AM4 o'clock  | 0x04              | PM4 o'clock    | 0x24              | 04 o'clock                     | 0x04           | 16 o'clock | 0x16              |
| AM5 o'clock  | 0x05              | PM5 o'clock    | 0x25              | 05 o'clock                     | 0x05           | 17 o'clock | 0x17              |
| AM6 o'clock  | 0x06              | PM6 o'clock    | 0x26              | 06 o'clock                     | 0x06           | 18 o'clock | 0x18              |
| AM7 o'clock  | 0x07              | PM7 o'clock    | 0x27              | 07 o'clock                     | 0x07           | 19 o'clock | 0x19              |
| AM8 o'clock  | 0x08              | PM8 o'clock    | 0x28              | 08 o'clock                     | 0x08           | 20 o'clock | 0x20              |
| AM9 o'clock  | 0x09              | PM9 o'clock    | 0x29              | 09 o'clock                     | 0x09           | 21 o'clock | 0x21              |
| AM10 o'clock | 0x10              | PM10 o'clock   | 0x30              | 10 o'clock                     | 0x10           | 22 o'clock | 0x22              |
| AM11 o'clock | 0x11              | PM11 o'clock   | 0x31              | 11 o'clock                     | 0x11           | 23 o'clock | 0x23              |



### 12.3.3 RTC initialization settings

- Step 1: Write 0xCA and 0x53 to the RTC\_KEY register sequentially to unlock the RTC register;
- Step 2: Configure RTC\_CR0.H24 bit field, select 12/24 time system;
- Step 3: Configure the RTC\_CR1.SOURCE bit field and select the RTC clock source;

#### Caution:

If you select LSE or LSI, you need to enable and start LSE or LSI first, and wait for the clock to stabilize.

- Step 4: Set the correct time and date values, write the time and date registers;
- Step 5: Configure the required periodic interrupt unit, automatic wake-up unit, alarm clock A, and alarm clock B;
- Step 6: Configure the RTC\_IER register, set the periodic interrupt, automatic wake-up interrupt, alarm A, alarm B interrupt;
- Step 7: Configure the time stamp function and configure the time stamp interruption;
- Step 8: The RTC\_CR0.START bit field is set to 1 to start the RTC timer;
- Step 9: Write 0xCA, 0x-- to the RTC\_KEY register sequentially to start the RTC register lock protection.

In user applications, when initializing the RTC, the reset state (SYSCTRL\_RESETFLAG) of the MCU should be checked first. If it is a power-on reset (SYSCTRL\_RESETFLAG.POR=1), the RTC registers will be reset to their default values. It is necessary to reconfigure the RTC control registers, RTC date and time registers, and restart the RTC; other reset conditions will not reset the RTC registers, the RTC continues to time normally.



Figure 12-2 RTC initialization process

Rev 1.0

### 12.3.4 Register lock function

After the CW32W031 is powered on and reset, the RTC registers except RTC\_KEY and RTC\_ICR are in lock protection state and cannot be modified. Write 0xCA and 0x53 keywords to the key value register RTC\_KEY in sequence to release the RTC register lock protection; write 0xCA and 0x-- to the RTC\_KEY register in sequence, the RTC register will be locked.

### 12.3.5 Register access operations

Since the running clock of the RTC counter may be out of sync with the clock of the RTC control register, when the RTC is running, in order to ensure that the register contents can be accessed correctly without affecting the operation of the RTC, the WINDOW bit field and the ACCESS bit of the control register RTC\_CR1 should be adjusted. The combined use of the fields ensures that the access operation to the RTC register does not affect the timing accuracy of the RTC.

To access the RTC registers when the RTC is already running, the following operating specifications must be followed:

- Step 1: Circularly check whether the WINDOW bit is 1, if it is 0, wait for 10ms to check again, lasting 1000 times, if 1 is still not detected after 1000 times, exit, and the return operation is not completed correctly;
- Step 2: Write 0xCA and 0x53 to the RTC\_KEY register sequentially to unlock the RTC register;
- Step 3: Write 1 to ACCESS to set up the access flag;
- Step 4: Execute normal RTC register access operation;

#### Caution:

This step can implement multiple RTC register access instructions, but the total execution time cannot exceed 1s.

- Step 5: Write 0 to ACCESS to clear the access flag;
- **Step 6:** Write 0xCA, 0x-- to the RTC\_KEY register sequentially to enable the write protection of the RTC register.

#### Caution:

If the user needs to read the RTC time and date information more quickly, he can choose to read the time or date register twice in a row. As long as the content of the two reads is the same, the read data can be considered valid.



§ Real time clock (RTC) CW32W031

### 12.3.6 RTCOUT output

By setting the RTCOUT bit field of the control register RTC\_CR2, the RTC\_OUT output source can be selected, as shown in the following table:

Table 12-2 RTC\_OUT output configuration

| RTC_CR2.RTCOUT | RTC_OUT output              |
|----------------|-----------------------------|
| 00             | Always output low level     |
| 01             | Alarm clock A match flag    |
| 10             | Alarm clock B match flag    |
| 11             | Wake-up timer overflow flag |

## 12.3.7 1Hz signal output

The RTC1HZ bit field of the control register RTC\_CR0 is used to set the RTC\_1Hz pin to output a compensated or uncompensated 1Hz signal, as shown in the following table:

Table 12-3 RTC\_1Hz output configuration

|                                             | RTC_CR0.RTC1HZ | RTC_CR1.SOURCE | RTC_1Hz output                         |
|---------------------------------------------|----------------|----------------|----------------------------------------|
| Disable error compensation                  | 01             | 000            | 32768 frequency division signal of LSE |
| (RTC_COMPEN.EN=0)                           | UI UI          | 010            | 32768 frequency division signal of LSI |
| Enable error compensation (RTC_COMPEN.EN=1) | 01             | -              | 1Hz signal with LSE error compensation |

### 12.3.8 Clock error compensation

The RTC has a built-in clock compensation circuit. When the LSE accuracy cannot meet the requirements, the RTC clock can be compensated to achieve higher precision RTC timing.

The RTC clock error compensation register RTC\_COMPEN has three bit fields for implementing error compensation:

- SIGN, compensation direction
  - When the actual LSE clock frequency is greater than 32768Hz, SIGN is set to 0 to compensate downward
  - When the actual LSE clock frequency is less than 32768Hz, SIGN is set to 1, upward compensation
- STEP, compensation period, 32, 128, 256 seconds can be selected as a compensation period
  - 32 seconds is a compensation period, which can achieve fast calibration but the accuracy is low, and the compensation accuracy is 0.950ppm;
  - When 128 is selected, the compensation accuracy is 0.238ppm;
  - When 256 is selected, the adjustment process is the smoothest, and the compensation accuracy is 0.119ppm;
- COMP, compensation value
  - When STEP is selected as 32, the valid range of COMP is  $1 \sim 511$
  - When STEP selects 128, the valid range of COMP is 1 ~ 2047
  - When STEP selects 256, the valid range of COMP is 1 ~ 4095

The operation steps of clock calibration are as follows:

- Step 1: Turn off the error compensation function and set RTC\_COMPEN.EN to 0;
- Step 2: According to *Table 9-2 GPIO multiplexing function assignment table*, configure a GPIO port as RTC\_1Hz output, output uncompensated 1Hz signal;
- Step 3: According to section 12.3.3 RTC initialization settings, configure LSE as the RTC clock source;
- Step 4: The RTC\_CR0.START bit field is set to 1 to start the RTC;
- Step 5: Use a high-precision frequency meter to measure the 1Hz signal output by the RTC\_1Hz pin, record the actual measurement frequency  $f_0$ ;

The calculation method of the compensation value COMP:

Assuming the measured value  $f_0$ = 0.9999888Hz, the actual frequency of the RTC clock  $f_z$ :

$$f_z = 32768 \times 0.9999888 \approx 32767.63$$
Hz

Frequency error  $\Delta f = 32768 - 32767.63 = 0.37$ 

Select the compensation period as 256, the calibration accuracy is the highest, and calculate the compensation value:

$$COMP = \Delta f \times STEP = 0.37 \times 256 = 94.72 \approx 95 = 0x5F$$

Step 6: According to section 12.3.5 Register access operations, configure the RTC\_COMPEN compensation register. In this example, write 1 to the SIGN bit field, write 10 to the STEP bit field, and the COMP bit field is 0x5F;

**Step 7:** Write RTC\_COMPEN.EN to 1 to start clock error compensation.

#### Caution:

Steps 6 and 7 can also be combined, directly operate by halfword, and write 0xE05F to RTC\_COMPEN.



#### 12.3.9 Alarm clock A and alarm clock B

RTC supports 2 independent alarm clocks (alarm clock A and alarm clock B), which can generate alarm events at any time of the week, and generate alarm interrupts, and output the alarm matching events through the external RTC\_OUT pin. Set the ALARMAEN and ALARMBEN bit fields of the control register RTC\_CR2 to 1 to enable the alarm clock A and the alarm clock B respectively.

By setting the hour, minute, second match control bits HOUREN, MINUTEEN, SECONDEN and the hour, minute, second count value HOUR, MINUTE, SECOND of the alarm clock A and B control registers (RTC\_ALARMA and RTC\_ALARMB), the alarm clock can be set at 'xx time xx Minutes xx seconds', or 'xx minutes xx seconds' or 'xx hours xx minutes' or 'xx hours' and other combinations to generate alarm events; the alarm week enable control bit WEEKMASK can select any day of the week to generate an alarm event , bit0 represents Sunday, and bits 1 to 6 represent Monday to Saturday.

Using 12 or 24 time system, the setting value of the alarm control register RTC\_ALARMx (x=A,B) may be different. The example is as follows:

| Timing requirement                                                | Time system | RTC_ALARMx value | Alarm clock time |
|-------------------------------------------------------------------|-------------|------------------|------------------|
| Alarm clock at 6:30 a.m. every morning                            | 12/24 time  | 0x7F06 3000      | 06: 30: 00       |
| Alarm clock at 7:00 every weekday                                 | 12/24 time  | 0x3E07 0000      | 07: 00: 00       |
| Occurs every hour at 50 minutes                                   | 12/24 time  | 0x7F80 5000      | xx: 50: 00       |
| Occurs every 10 seconds per minute                                | 12/24 time  | 0x7F80 8010      | xx: xx: 10       |
| Every Monday, it occurs every five seconds per minute at 12 noon. | 12 time     | 0x0232 8005      | 12PM: xx: 05     |
| Every Monday, it occurs every five seconds per minute at 12 noon. | 24 time     | 0x0212 8005      | 12: xx: 05       |
| Every Sunday, it occurs per second at 12: 30 p.m.                 | 12 time     | 0x0112 3080      | 12AM: 30: xx     |
| Every Sunday, it occurs per second at 12: 30 p.m.                 | 24 time     | 0x0100 3080      | 00: 30: xx       |

Table 12-4 Examples of timed alarm clocks

When an alarm event occurs, the corresponding alarm match flag bit RTC\_ISR.ALARMx will be set to 1 by hardware. If the alarm interrupt enable bit RTC\_IER.ALARMx is set to 1, an interrupt request will be generated.

The match flag of alarm A or alarm B can be output through RTC\_OUT pin, please refer to section 12.3.6 RTCOUT output.

### 12.3.10 Period interrupt function

The RTC has a built-in period interrupt module, which can generate fixed-period interrupt signals. The timing period is configured by the INTERVAL bit field of the control register RTC\_CR0, as shown in the following table:

Table 12-5 Timing period configuration

| RTC_CR0. INTERVAL | Period of Period Interrupt                            |
|-------------------|-------------------------------------------------------|
| 000               | No period interrupt is generated                      |
| 001               | 0.5 seconds, generated every 1 second and 0.5 seconds |
| 010               | 1 second, generated when the seconds counter changes  |
| 011               | 1 minute, generated when the minute counter changes   |
| 100               | 1 hour, generated when the hour counter changes       |
| 101               | 1 day, generated when the day counter changes         |
| 11x               | 1 month, generated when the month counter changes     |

Through the INTERVAL bit field of the RTC interrupt enable register RTC\_IER, it is possible to set whether the period interrupt generates an interrupt request.

### 12.3.11 Automatic wake-up function

The automatic wake-up timer is a 16-bit programmable automatic reload subtraction counter, with a selectable clock source, and the timing range is:  $61\mu s \sim 145h$ . When the counter overflows, it can generate an automatic wake-up interrupt and output the overflow flag through the RTC\_OUT pin.

Set the AWTEN bit field of the control register RTC\_CR2 to 1 to enable the automatic wake-up function, which is specially designed for low-power applications and can work in all working modes of the MCU.

The AWTSRC bit field of the RTC control register RTC\_CR2 is used to select the count clock source of the automatic wake-up timer, as shown in the following table:

RTC\_CR2.AWTSRC Clock source of period interrupt 000 RTCCLK/2 (~16384Hz) 001 RTCCLK/4 (~8192Hz) 010 RTCCLK/8 (~4096Hz) 011 RTCCLK/16 (~2048Hz) 100  $RTC1Hz/1 (\sim 1Hz)^{\perp}$ 101  $RTC1Hz/2 (\sim 0.5Hz)^{1}$ 110  $RTC1Hz/4 (\sim 0.25Hz)^{\perp}$ 111  $RTC1Hz/8 (\sim 0.125Hz)^{\perp}$ 

Table 12-6 Automatic wake-up timer clock source selection

### Caution1:

RTC must be running when RTC1Hz is selected as clock source (RTC\_CR0.START = 1)

The count period of the automatic wake-up timer is determined by the count clock source and the reload register RTC\_AWTARR. The formula for calculating the timing duration is:

Auto wake-up timer period = (RTC\_AWTARR+1) / wake-up timer clock frequency

Shortest timing:  $(0+1) / 16384Hz = 61\mu s$ 

Longest timing: (65535+1) / 0.125Hz = 524288s = 8738min  $\approx 145.63$ h

Through the AWTIMER bit field of the RTC interrupt enable register RTC\_IER, you can select whether to generate an interrupt request when the automatic wake-up timer overflows. The overflow flag of the automatic wake-up timer can be output through the RTC\_OUT pin, see section 12.3.6 RTCOUT output.

### 12.3.12 Timestamp function

The RTC supports the timestamp function, that is, triggered by the RTC\_TAMP pin, the current time and date are saved to the timestamp date register RTC\_TAMPDATE and the timestamp time register RTC\_TAMPTIM, and a timestamp interrupt can be generated at the same time.

The TAMPEDGE bit field of the control register RTC\_CR2 is used to select whether the signal triggering the timestamp is valid on the rising edge or the falling edge, and the TAMPEN bit field of the RTC\_CR2 register is used to enable the timestamp function.

Users can flexibly select the trigger pin RTC\_TAMP, and need to configure this pin as a digital input and multiplexing function, please refer to the pin definition in the datasheet for more details.

When a timestamp event occurs, the timestamp event flag bit RTC\_ISR.TAMP will be set to 1. If the timestamp interrupt enable bit RTC\_IER.TAMP is set to 1, an interrupt request will be generated.

If after the first timestamp event occurs, the RTC\_ISR.TAMP flag is not cleared by software, and the second timestamp event occurs, the timestamp overflow flag RTC\_ISR.TAMPOV will be set to 1. If the timestamp overflow interrupt is set, the When the enable bit RTC\_IER.TAMPOV is 1, an interrupt request will be generated.

### 12.3.13 RTC Interrupts

RTC supports 6 interrupt sources: wake-up interrupt, alarm A interrupt, alarm B interrupt, period interrupt, timestamp interrupt and timestamp overflow interrupt.

The opening of the interrupt is controlled by the interrupt enable register RTC\_IER. Write '1' to the corresponding bit field to enable the interrupt, and write '0' to disable the interrupt; when an interrupt occurs, the hardware will automatically set the corresponding bit of the interrupt flag register RTC\_ISR; Write '0' to the corresponding bit of the register RTC\_ICR to clear the corresponding interrupt flag.

In the user application, after the RTC interrupt function is enabled, the same interrupt service routine will be called from the RTC interrupt entry (RTC\_IRQHandler) when all RTC interrupt events occur. The specific RTC interrupt source.

After the interrupt event processing is completed, before exiting the interrupt service routine, you must write '0' to the corresponding bit of the RTC interrupt flag clear register RTC\_ICR to clear the interrupt flag and avoid repeatedly entering the interrupt service routine.

# 12.4 List of registers

RTC base address: RTC\_BASE = 0x4000 2800

Table 12-7 List of RTC registers

| Register name | Register address | Register description              |
|---------------|------------------|-----------------------------------|
| RTC_KEY       | RTC_BASE + 0x00  | Key value register                |
| RTC_CR0       | RTC_BASE + 0x04  | Control register 0                |
| RTC_CR1       | RTC_BASE + 0x08  | Control register 1                |
| RTC_CR2       | RTC_BASE + 0x0C  | Control register 2                |
| RTC_COMPEN    | RTC_BASE + 0x10  | Clock error compensation register |
| RTC_DATE      | RTC_BASE + 0x14  | Date register                     |
| RTC_TIME      | RTC_BASE + 0x18  | Time register                     |
| RTC_ALARMA    | RTC_BASE + 0x1C  | Alarm clock A control register    |
| RTC_ALARMB    | RTC_BASE + 0x20  | Alarm clock B control register    |
| RTC_TAMPDATE  | RTC_BASE + 0x24  | Timestamp date register           |
| RTC_TAMPTIME  | RTC_BASE + 0x28  | Timestamp time register           |
| RTC_AWTARR    | RTC_BASE + 0x2C  | Wake-up timer reload register     |
| RTC_IER       | RTC_BASE + 0x30  | Interrupt enable register         |
| RTC_ISR       | RTC_BASE + 0x34  | Interrupt flag register           |
| RTC_ICR       | RTC_BASE + 0x38  | Interrupt flag clear register     |

# 12.5 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

## 12.5.1 RTC\_KEY key value register

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                           |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                   |
| 7:0       | KEY  | WO         | Key value register Write "0x00CA" and "0x0053" to this register in turn to modify the register of the RTC module. Write "0x00CA" and "0x" to this register in turn, and the registers of the RTC module cannot be modified except for KEY and ICR. Caution: "0x" is any value except "0x0053". |

# 12.5.2 RTC\_CR0 control register 0

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8      | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                               |
| 7         | START    | RW         | RTC timer operation control 0: Stop RTC timer 1: Start RTC timer                                                                                                                                                                                                                                                                                                                                                           |
| 6:5       | RTC1HZ   | RW         | RTC_1Hz output configuration 01: 1Hz signal compensated by LSE clock Others: Reserved Caution: If RTC_ COMPEN.EN is 0, 32768 frequency division of LSE or LSI is output                                                                                                                                                                                                                                                    |
| 4         | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                               |
| 3         | H24      | RW         | Timing system setting 0: 12 time system 1: 24 time system                                                                                                                                                                                                                                                                                                                                                                  |
| 2:0       | INTERVAL | RW         | Timing period setting 000: No timing period is generated 001: 0.5 second, generated when the second timer changes and the 0.5 second moment 010: one second, generated when the second timer changes 011: one minute, generated when the minute timer changes 100: one hour, generated when the hour timer changes 101: one day, generated when the day timer changes 11x: January, generated when the month timer changes |

# 12.5.3 RTC\_CR1 control register 1

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                              |
|-----------|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11     | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                      |
| 10:8      | SOURCE | RW         | Timing clock RTCCLK source configuration 000: External low frequency clock LSE 010: Built-in low frequency clock LSI 100: External high-speed clock HSE, 128 frequency division 101: External high-speed clock HSE, 256 frequency division 110: External high-speed clock HSE, 512 frequency division 111: External high-speed clock HSE, 1024 frequency division |
| 7:2       | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                      |
| 1         | WINDOW | RO         | RTC register access window status  0: Non-read and write window, it is not recommended to read and write registers  1: Read and write window, you can read and write registers                                                                                                                                                                                    |
| 0         | ACCESS | RW         | RTC timing related register access control 0: Normal counting mode 1: Write/read mode Caution: This control bit needs to be set when read and write access to the register is required, and the write/read operation is completed within 1 second, and then this bit is cleared to 0. If ACCESS is set to 1 for more than 1 second, it may cause timing errors.   |

# 12.5.4 RTC\_CR2 control register 2

Address offset: 0x0C Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                                                                                                                                                                                                                            |
|-----------|----------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11     | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                    |
| 10        | ALARMBEN | RW         | Alarm clock B enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                             |
| 9         | ALARMAEN | RW         | Alarm clock A enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                             |
| 8         | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                    |
| 7         | AWTEN    | RW         | Wake-up timer enable control 0: Wake-up timer disabled 1: Wake-up timer enabled                                                                                                                                                                                                                 |
| 6         | TAMPEN   | RW         | Timestamp enable control 0: Timestamp function disabled 1: Timestamp function enabled                                                                                                                                                                                                           |
| 5:4       | RTCOUT   | RW         | RTC_OUT output configuration 00: Output low level 01: Alarm clock A match flag 10: Alarm clock B match flag 11: Wake-up timer overflow flag                                                                                                                                                     |
| 3         | TAMPEDGE | RW         | Timestamp signal edge configuration  0: Record the current time on the rising edge of the RTC_ TAMP pin  1: Record the current time on the falling edge of the RTC_ TAMP pin                                                                                                                    |
| 2:0       | AWTSRC   | RW         | Wake-up timer count clock source configuration 000: RTCCLK / 2 ~ 16384Hz 001: RTCCLK / 4 ~ 8192Hz 010: RTCCLK / 8 ~ 4096Hz 011: RTCCLK / 16 ~ 2048Hz 100: RTC1Hz / 1 ~ 1Hz 101: RTC1Hz / 2 ~ 0.5Hz 110: RTC1Hz / 4 ~ 0.25Hz 111: RTC1Hz / 8 ~ 0.125Hz Caution: 0.125Hz ~ 1Hz need to enable RTC |

# 12.5.5 RTC\_COMPEN clock error compensation register

Address offset: 0x10 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                |
|-----------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                        |
| 15        | EN   | RW         | Clock error compensation enable control 0: Clock error compensation disabled 1: Clock error compensation enabled                                                                                                                                                                                    |
| 14        | SIGN | RW         | Clock compensation direction 0: Increase the count value (LSE oscillation frequency is greater than 32768Hz) 1: Decrease the count value (LSE oscillation frequency is less than 32768Hz)                                                                                                           |
| 13:12     | STEP | RW         | Compensation step selection 00: 0.950ppm, the compensation rate is COMP[08:0] / 32768 / 32 01: 0.238ppm, the compensation rate is COMP[10:0] / 32768 / 128 10: 0.119ppm, the compensation rate is COMP[11:0] / 32768 / 256 Caution: The compensation accuracy is half of the compensation step size |
| 11:0      | COMP | RW         | Compensation value<br>Compensable range is ±488.0ppm                                                                                                                                                                                                                                                |

# 12.5.6 RTC\_DATE date register

Address offset: 0x14 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                                                                |
|-----------|-------|------------|---------------------------------------------------------------------------------------------------------------------|
| 31:27     | RFU   | -          | Reserved bits, please keep the default value                                                                        |
| 26:24     | WEEK  | RW         | Week count value BCD code format, valid value range is 0 ~ 6 0 represents Sunday, 1~6 represents Monday to Saturday |
| 23:16     | YEAR  | RW         | Year count value<br>BCD code format, valid value range is 00~99                                                     |
| 15:8      | MONTH | RW         | Month count value<br>BCD code format, valid value range is 1 ~ 12                                                   |
| 7:0       | DAY   | RW         | Day count value BCD code format, the valid value range is $1\sim28,1\sim29,1\sim30,1\sim31$                         |

## 12.5.7 RTC\_TIME time register

Address offset: 0x18 Reset value: 0x0012 0000

| Bit field | Name   | Permission Function description |                                                                                                                                                                                                                                  |
|-----------|--------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22     | RFU    | -                               | Reserved bits, please keep the default value                                                                                                                                                                                     |
| 21:16     | HOUR   | RW                              | Hour count value 24 time system, the valid value range of hour count BCD code is $0 \sim 23$ 12 time system, the valid value range of BCD code for hour count is $1 \sim 12$ (AM), $21 \sim 32$ (PM) bit21 is 0 for AM, 1 for PM |
| 15        | RFU    | -                               | Reserved bits, please keep the default value                                                                                                                                                                                     |
| 14:8      | MINUTE | RW                              | Minute count value<br>BCD code format, valid value range is 0 ~ 59                                                                                                                                                               |
| 7         | RFU    | -                               | Reserved bits, please keep the default value                                                                                                                                                                                     |
| 6:0       | SECOND | RW                              | Second count value<br>BCD code format, valid value range is 0 ~ 59                                                                                                                                                               |

# 12.5.8 RTC\_ALARMA alarm clock A control register

Address offset: 0x1C Reset value: 0x0012 0000

| Bit field | Name     | Permission                                                                                                                                                                 | Function description                                                                                                                                          |
|-----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31        | RFU      | -                                                                                                                                                                          | Reserved bits, please keep the default value                                                                                                                  |
| 30:24     | WEEKMASK | RW Alarm clock week enable control bit0 represents Sunday, bit1 ~ bit6 represent Monday to Saturday respectively If the corresponding bit is 1, the alarm clock is enabled |                                                                                                                                                               |
| 23        | HOUREN   | RW                                                                                                                                                                         | Alarm clock hour bit mask control 0: The alarm clock needs to check the hour count value 1: The alarm clock has nothing to do with the hour count value       |
| 22        | RFU      | -                                                                                                                                                                          | Reserved bits, please keep the default value                                                                                                                  |
| 21:16     | HOUR     | RW                                                                                                                                                                         | Alarm clock hour count value, BCD format                                                                                                                      |
| 15        | MINUTEEN | RW                                                                                                                                                                         | Alarm clock minute bit mask control 0: The alarm clock needs to check the minute count value 1: The alarm clock has nothing to do with the minute count value |
| 14:8      | MINUTE   | RW                                                                                                                                                                         | Alarm clock minute count value, BCD format                                                                                                                    |
| 7         | SECONDEN | RW                                                                                                                                                                         | Alarm clock second bit mask control 0: The alarm clock needs to check the second count value 1: The alarm has nothing to do with the second count value       |
| 6:0       | SECOND   | RW                                                                                                                                                                         | Alarm clock second count value, BCD format                                                                                                                    |

## 12.5.9 RTC\_ALARMB alarm clock B control register

Address offset: 0x20 Reset value: 0x0012 0000

| Bit field | Name     | Permission | Function description                                                                                                                                                    |
|-----------|----------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31        | RFU      | -          | Reserved bits, please keep the default value                                                                                                                            |
| 30:24     | WEEKMASK | RW         | Alarm clock week enable control bit0 represents Sunday, bit1 ~ bit6 represent Monday to Saturday respectively If the corresponding bit is 1, the alarm clock is enabled |
| 23        | HOUREN   | RW         | Alarm clock hour bit mask control 0: The alarm has nothing to do with the hour count value 1: The alarm clock needs to check the hour count value                       |
| 22        | RFU      | -          | Reserved bits, please keep the default value                                                                                                                            |
| 21:16     | HOUR     | RW         | Alarm hour count value in BCD format                                                                                                                                    |
| 15        | MINUTEEN | RW         | Alarm clock minute bit mask control 0: The alarm has nothing to do with the minute count value 1: The alarm clock needs to check the minute count value                 |
| 14:8      | MINUTE   | RW         | Alarm clock minute count value, BCD format                                                                                                                              |
| 7         | SECONDEN | RW         | Alarm clock second bit mask control 0: The alarm has nothing to do with the second count value 1: The alarm clock needs to check the second count value                 |
| 6:0       | SECOND   | RW         | Alarm clock second count value, BCD format                                                                                                                              |

## 12.5.10 RTC\_TAMPDATE timestamp date register

Address offset: 0x24 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                           |  |
|-----------|-------|------------|------------------------------------------------|--|
| 31:16     | RFU   | -          | Reserved bits, please keep the default value   |  |
| 15:13     | WEEK  | RO         | Week count value when time stamp signal occurs |  |
| 12:8      | MONTH | RO         | Month count value when timestamp signal occurs |  |
| 7:6       | RFU   | -          | Reserved bits, please keep the default value   |  |
| 5:0       | DAY   | RO         | Day count value when timestamp signal occurs   |  |

## 12.5.11 RTC\_TAMPTIME timestamp time register

Address offset: 0x28 Reset value: 0x0000 0000

| Bit field | Name   | Permission Function description |                                                     |
|-----------|--------|---------------------------------|-----------------------------------------------------|
| 31:22     | RFU    | -                               | Reserved bits, please keep the default value        |
| 21:16     | HOUR   | RO                              | Hour count value when timestamp signal occurs       |
| 15        | RFU    | -                               | Reserved bits, please keep the default value        |
| 14:8      | MINUTE | RO                              | The minute count value when timestamp signal occurs |
| 7         | RFU    | -                               | Reserved bits, please keep the default value        |
| 6:0       | SECOND | RO                              | The second count value when timestamp signal occurs |

## 12.5.12 RTC\_AWTARR wake-up timer reload value

Address offset: 0x2C Reset value: 0x0000 FFFF

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | ARR  | RW         | Wake-up timer reload value                   |

# 12.5.13 RTC\_IER interrupt enable register

Address offset: 0x30 Reset value: 0x0000 0000

| Bit field | Name     | Permission                                                       | Function description                                               |
|-----------|----------|------------------------------------------------------------------|--------------------------------------------------------------------|
| 31:7      | RFU      | -                                                                | Reserved bits, please keep the default value                       |
| 6         | INTERVAL | Timing period interrupt enable control RW 0: Disabled 1: Enabled |                                                                    |
| 5         | RFU      | -                                                                | Reserved bits, please keep the default value                       |
| 4         | TAMPOV   | RW                                                               | Timestamp overflow interrupt enable control 0: Disabled 1: Enabled |
| 3         | TAMP     | RW                                                               | Timestamp interrupt enable control 0: Disabled 1: Enabled          |
| 2         | AWTIMER  | RW                                                               | Wake up timer interrupt enable control 0: Disabled 1: Enabled      |
| 1         | ALARMB   | RW                                                               | Alarm clock B interrupt enable control 0: Disabled 1: Enabled      |
| 0         | ALARMA   | RW                                                               | Alarm clock A interrupt enable control 0: Disabled 1: Enabled      |

# 12.5.14 RTC\_ISR interrupt flag register

Address offset: 0x34 Reset value: 0x0000 0000

| Bit field | Name     | Permission                                                                                                                                 | Function description                                                                                                                                |
|-----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7      | RFU      | -                                                                                                                                          | Reserved bits, please keep the default value                                                                                                        |
| 6         | INTERVAL | Periodic timing completion flag  RO  0: No periodic timing completion event occurred  1: The periodic timing completion event has occurred |                                                                                                                                                     |
| 5         | RFU      | -                                                                                                                                          | Reserved bits, please keep the default value                                                                                                        |
| 4         | TAMPOV   | RO                                                                                                                                         | Timestamp overflow flag  0: No timestamp overflow event occurred  1: The timestamp overflow event has occurred                                      |
| 3         | TAMP     | RO                                                                                                                                         | Timestamp event flag 0: No timestamp event occurred 1: Timestamp event has occurred                                                                 |
| 2         | AWTIMER  | RO                                                                                                                                         | Wake-up timer timing completion flag 0: No wake-up timer timing completion event occurred 1: The wake-up timer timing completion event has occurred |
| 1         | ALARMB   | RO                                                                                                                                         | Alarm clock B match flag 0: No alarm clock B match event occurred. 1: The alarm clock B match event has occurred                                    |
| 0         | ALARMA   | RO                                                                                                                                         | Alarm clock A match flag 0: No alarm clock A match event occurred. 1: Alarm clock A match event has occurred                                        |

# 12.5.15 RTC\_ICR interrupt flag clear register

Address offset: 0x38 Reset value: 0x0000 007F

| Bit field | Name     | Permission                                                                                                   | Function description                                                                                              |
|-----------|----------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:7      | RFU      | -                                                                                                            | Reserved bits, please keep the default value                                                                      |
| 6         | INTERVAL | Periodic timing completion flag cleared  R1W0 W0: Clear the periodic timing completion flag  W1: No function |                                                                                                                   |
| 5         | RFU      | -                                                                                                            | Reserved bits, please keep the default value                                                                      |
| 4         | TAMPOV   | R1W0                                                                                                         | Timestamp overflow flag cleared<br>W0: Clear timestamp overflow flag<br>W1: No function                           |
| 3         | TAMP     | R1W0                                                                                                         | Timestamp event flag cleared<br>W0: Clear timestamp event flag<br>W1: No function                                 |
| 2         | AWTIMER  | R1W0                                                                                                         | Wake-up timer timing completion flag cleared<br>W0: Clear wake-up timer timing completion flag<br>W1: No function |
| 1         | ALARMB   | R1W0                                                                                                         | Alarm clock B match flag cleared<br>W0: Clear alarm clock B match flag<br>W1: No function                         |
| 0         | ALARMA   | R1W0                                                                                                         | Alarm clock A match flag cleared<br>W0: Clear alarm clock A match flag<br>W1: No function                         |

## 13 Basic timer (BTIM)

#### 13.1 Overview

CW32W031 integrates three basic timers (BTIM), each BTIM is completely independent and has the same function, each contains a 16-bit automatic reload counter and is driven by a programmable prescaler. BTIM supports four working modes: timer mode, counter mode, trigger start mode and gate control mode, and supports overflow event trigger interrupt request and DMA request. Thanks to the fine processing design of the trigger signal, the BTIM can automatically perform the filtering operation of the trigger signal by the hardware, and can also cause the trigger event to generate interrupts and DMA requests.

### 13.2 Main features

- 16-bit auto-reload up counter
- Programmable prescaler supports 1, 2, 3, 4, ···, 65536 frequency division
- Supports single counting mode and continuous counting mode
- Counting function for internal ITR or external ETR signal
- Internal ITR or external ETR signal triggers to start counting
- Gated function controlled by external ETR input signal
- Flexible external ETR signal filter processing
- Overflow event triggers digital output level transition
- Internal cascade ITR and external interconnect ETR
- Counter overflow triggers interrupt/DMA request
- Internal ITR or external ETR signal triggers interrupt/DMA request



## 13.3 Functional description

### 13.3.1 Functional block diagram

The functional block diagram of BTIM is shown in the following figure:

BCR TOGEN PSC PCLK TOGP TCLK ITR Prescaler TOG /1, 2, ... / 65536 Control TOGN TCLKD Polarity Edge 0 √ OV FILTER selection detection ARR overflow Trig IER.O\ interrupt 16-bit up counter ACR.ETRFLT BCR.POL BCR.TRS TOP Gate TOP overflow IER.TOP interrupt Reload register Legend: IER.TI -Trigger Event

Figure 13-1 BTIM functional block diagram

### 13.3.1.1 Filter unit

BTIM supports filtering the signal input from external BTIM\_ETR pin. The filter samples the ETR signal at a certain sampling frequency. When N consecutive samples of the same level are obtained, the signal is valid, otherwise the signal is invalid, so as to filter out high-frequency clutter signals.

The sampling clock of the filter unit is PCLK or a frequency division of PCLK. The frequency division ratio of PCLK and the number of sampling points N can be selected through the ETRFLT bit field of the advanced control register BTIMx\_ACR.

#### Caution:

Since the hardware samples the signal input from the external BTIM\_ETR pin with the PCLK clock or the frequency division of the PCLK clock, the input signal whose frequency is higher than half of the actual sampling frequency may be missed.

The following example illustrates the relationship between the configuration of BTIMx\_ACR.ETRFLT and the cutoff frequency.

### Example:

When the PCLK clock frequency is 24MHz, set BTIMx\_ACR.ETRFLT to 0x05 (ie  $F_{sample}$  = PCLK / 4 and N = 6), then

$$F_{\text{sample}} = 6MHz, N = 6$$

Continuous sampling to 6 valid levels, the required time is:

$$6 \times T_{sample} = 1 \mu s$$

Therefore, input signals with frequencies above 0.5MHz will be filtered out.



204 / 572 Rev 1.0

### 13.3.1.2 Polarity selection unit

When the BTIM is configured in gated mode, the polarity selection unit is used to select whether the signal input by the external BTIM\_ETR pin is active high or active low, which is selected by the POL bit field of the basic control register BTIMx\_BCR.

When setting BTIMx\_BCR.POL to 0, the ETR signal is valid when it is high; when setting BTIMx\_BCR.POL to 1, it is valid when the ETR signal is low level.

### 13.3.1.3 Edge detection unit

When the BTIM is configured in the trigger start mode, the edge detection unit is used to select the edge trigger timing of the signal input by the external BTIM\_ETR pin. Specifically, it is selected through the POL bit field of the basic control register BTIMx\_BCR.

When BTIMx\_BCR.POL is set to 0, the ETR signal is valid when the rising edge is set; when BTIMx\_BCR.POL is set to 1, the ETR signal is valid when the falling edge is set.

#### 13.3.1.4 Prescaler

The prescaler coefficient is configured by the BTIMx\_PSC register, and the specific frequency division coefficient is related to the counter clock source TCLK. When the counter clock source is PCLK, the frequency division coefficient is PSC+1; when the counter clock source is TRS, the frequency division coefficient is PSC (PSC>0).

It is allowed to modify BTIMx\_PSC during the timer operation, but the new prescale factor will not take effect immediately. When the timer overflows or the running control bit BTIMx\_BCR.EN changes from 0 to 1, the new prescale factor takes effect.

An example of changing the prescaler coefficient during operation is shown in the following figure:

Figure 13-2 Timing diagram of the counter with the prescaler coefficient changing from 1 to 2 (ARR=0xFD)





205 / 572 Rev 1.0

### 13.3.1.5 Counting unit

The core component of the counting unit is a 16-bit up counter CNT and a 16-bit automatic reload register ARR.

It is allowed to modify the reload register ARR while the timer is running, and the value of ARR will take effect immediately. When the value of the counter CNT is less than the value of ARR, after modifying the current ARR value to be less than the current CNT value, the ARR overflow signal OV will not be generated, and restart counting from 0x0000.

The counter can work in single counting or continuous counting mode, which is selected by the ONESHOT bit field of the basic control register BTIMx\_BCR.

### Single counting mode

Set BTIMx\_BCR.ONESHOT to 1 to make the timer work in one-shot counting mode. Set BTIMx\_BCR.EN to 1 to enable BTIMx, and the counter CNT counts up under the drive of the count clock TCLKD. When the count value reaches the reload value ARR, the overflow signal OV is generated (the overflow signal OV is kept for one PCLK cycle and then automatically cleared), when the OV signal is cleared, the counter ARR overflow flag bit BTIMx\_ISR.OV is set by hardware, and the counter stops counting at the same time, BTIMx\_BCR.EN is automatically reset by hardware.

The following figure is an example of single counting mode:



Figure 13-3 Single counting mode(PSC=0x01, ARR=0xFC)

**Rev 1.0** 

### Continuous counting mode

Set BTIMx\_BCR.ONESHOT to 0 to make the timer work in continuous counting mode. Set BTIMx\_BCR.EN to 1 to enable BTIMx, and the counter CNT counts up under the drive of the count clock TCLKD. When the count value reaches the reload value ARR, an overflow signal OV is generated (the overflow signal OV remains for one PCLK cycle, and then automatically cleared). When the count value changes from ARR to 0, the counter ARR overflow flag bit BTIMx\_ISR.OV is set by hardware, and the counter starts to count up in the next period.

The following figure is an example of continuous counting mode:

Figure 13-4 Continuous counting mode (PSC=0x00, ARR=0xFC)





### 13.3.1.6 Flip output unit

The flip output unit can control the external BTIMx\_TOGP and BTIMx\_TOPN pins to output the flip signal through the ARR overflow signal OV.

When BTIMx\_BCR.TOGEN is set to 0, both BTIMx\_TOGP and BTIMx\_TOPN pins output low level.

When BTIMx\_BCR.TOGEN is set to 1, the BTIMx\_TOGP and BTIMx\_TOPN pins output signals with opposite levels (BTIMx\_TOGP default level is high); when the counter ARR overflows (BTIMx\_ISR.OV is 1), the output levels of BTIMx\_TOGP and BTIMx\_TOPN pins will flip.

The following figure shows the schematic diagram of BTIMx\_TOGP and BTIMx\_TOPN pins level flip output in continuous counting mode:

Figure 13-5 Schematic diagram of level flip output (continuous counting mode, ARR=0x0B)



The TOGP/TOGN pins supported by BTIM are shown in the following table, and the corresponding GPIOs need to be multiplexed during application.



Table 13-1 BTIM toggle output pins

| TOGP/TOGN    | Pin            | AFR  |
|--------------|----------------|------|
| BTIM1_TOGP   | PA10/PB00/PF01 | 0x04 |
| BTIM1_TOGN   | PA07/PA09/PF00 | 0x04 |
| BTIM2_TOGP   | PA08           | 0x03 |
| DTIMZ_TOGP   | PA06/PC15      | 0x04 |
| BTIM2_TOGN   | PB15           | 0x03 |
| BTIMZ_TOGN   | PA05/PC14      | 0x04 |
| BTIM3_TOGP   | PB02           | 0x05 |
| BTIMS_TOGP   | PF07           | 0x07 |
| BTIM3_TOGN   | PB01           | 0x05 |
| DITIVID_TOUN | PF06           | 0x07 |

## 13.3.2 Operating modes

BTIM supports 4 operating modes: timer mode, counter mode, trigger start mode and gated mode. Configured through the MODE bit field of the basic control register BTImx\_BCR.

Table 13-2 BTIM operating modes

| Basic timer         | MODE bit field value | Operating mode     | Description                                                                           |
|---------------------|----------------------|--------------------|---------------------------------------------------------------------------------------|
|                     | 00                   | Timer mode         | The clock source is PCLK                                                              |
|                     | 01                   | Counter mode       | The counting source is TRS signal                                                     |
| BTIMx_BCR (x=1,2,3) | 10                   | Trigger start mode | The clock source is PCLK, and the TRS signal triggers the counter to start            |
|                     | 11                   | Gated mode         | The clock source is PCLK, and the ETR input signal is used as the gate control signal |

#### 13.3.2.1 Timer mode

The timer mode is mainly used to generate a time base signal with a fixed time interval. In this mode, the counter clock source is the internal system clock PCLK, which is divided by the prescaler to obtain the count clock TCLKD to drive the counter CNT to count. The functional block diagram of timer mode is shown in the following figure:

PSC **PCLK BCR.TOGEN** TCLK Prescaler /1, 2, ... / 65536 √ TOGP TOG Control ,TCLKD TOGN Trig О۷ 16-bit up counter Overflow CNT interrupt IER.OV Gate Reload register ARR

Figure 13-6 Timer mode block diagram

Set BTIMx\_BCR.MODE to 0x00 to make BTIMx work in timer mode. Set BTIMx\_BCR.EN to 1 to enable BTIMx, and the counter CNT will count up under the drive of the count clock TCLKD. When the count value reaches the reload value ARR, an overflow occurs, and the counter ARR overflow flag bit BTIMx\_ISR.OV is set by hardware. If the interrupt is enabled (set the interrupt enable register BTIMx\_IER.OV to 1), the CPU will respond to the interrupt service routine. Before exiting the interrupt service routine, the interrupt flag clear register BTIMx\_ICR.OV should be set to 0 to clear this flag.

In practical applications, the frequency of the system clock PCLK is known. By setting the prescaler coefficient PSC reasonably, the clock with a fixed duration can be counted, and the setting of the reload value ARR and the use of the counter ARR overflow interrupt flag bit, you can accurately obtain a specific time period, so as to achieve the purpose of timing.

Timing time T calculation formula:

$$T = ((PSC+1)/PCLK) \times (ARR+1)$$

Where, PCLK is the counter clock source, PSC is the prescaler coefficient, and ARR is the reload value.

#### Example:

When the frequency of the counter clock source PCLK is 24MHz, the timing is required to be 100ms. If the prescaler coefficient PSC is set to 0xFF, calculate:

$$T = 100 \text{ms} = ((255+1)/24 \text{MHz}) \times (ARR+1)$$

then

ARR = 9374 (0x249E)

That is, you need to set the reload value ARR to 0x249E.



211 / 572 Rev 1.0

#### 13.3.2.2 Counter mode

The counter mode is mainly used to measure the number of occurrences of an event. It can choose to count the signal input by the internal ITR or external BTIM\_ETR pin, which is selected by the TRS bit field of the basic control register BTIMx\_BCR.

When BTIMx\_BCR.TRS is set to 1, the counting source is the internal ITR signal (refer to *Table 13-10 ITR source configuration*); when BTIMx\_BCR.TRS is set to 0, the counting source is the signal input from the external BTIM\_ETR pin, and this counting is selected When the source is used, the filter can be configured through BTIMx\_ACR.ETRFLT, and the rising or falling edge of the ERT signal can be selected through BTIMx\_BCR.POL to count.

The functional block diagram of counter mode is shown in the following figure:



Figure 13-7 Counter mode block diagram

Set BTIMx\_BCR.MODE to 0x01 to make BTIMx work in counter mode. Set BTIMx\_BCR.EN to 1 to enable BTIMx, and the counter CNT counts up the divided TCLKD signal. When the count value reaches the reload value ARR, an overflow occurs, and the counter ARR overflow flag bit BTIMx\_ISR.OV is set by hardware. If the interrupt is enabled (set the interrupt enable register BTIMx\_IER.OV to 1), the CPU will respond to the interrupt service routine. Before exiting the interrupt service routine, the interrupt flag clear register BTIMx\_ICR.OV should be set to 0 to clear this flag.

For the specific register configuration process in counter mode, see section 13.5 Programming examples.



212 / 572 Rev 1.0

### 13.3.2.3 Trigger start mode

Set BTIMx\_BCR.MODE to 0x02 to make BTIMx work in trigger start mode. In this mode, when BTImx\_BCR.EN is set to 1 or the trigger signal is valid, the counter CNT will be started to count the TCLKD signal after the internal clock PCLK is divided by the prescaler.

The trigger signal can be selected from the internal ITR signal or the signal input from the external BTIM\_ETR pin, which is selected by the TRS bit field of the basic control register BTIMx\_BCR. When BTIMx\_BCR.TRS is set to 1, the trigger source is the internal ITR signal (see *Table 13-10 ITR source configuration*); when BTIMx\_BCR.TRS is set to 0, the trigger source is the external BTIM\_ETR pin input signal, select When this trigger source is used, the filter can be configured through BTIMx\_ACR.ETRFLT, and the ERT signal can be selected through BTIMx\_BCR.POL to be valid on rising or falling edges.

The functional block diagram of trigger start mode is shown in the following figure:



Figure 13-8 Trigger start mode block diagram

When a valid trigger signal is detected, the following effects occur:

- 1. BTIMx BCR.EN is set by hardware;
- 2. Trigger flag bit BTMx\_ISR.TI is set by hardware;
- 3. The counter starts and starts counting.

After the counter starts, the counter starts to count up from the initial value. When the count value reaches the reload value ARR, an overflow occurs, and the counter ARR overflow flag bit BTIMx\_ISR.OV is set by hardware. If the interrupt is enabled (set the interrupt enable register BTIMx\_IER.OV to 1), the CPU will respond to the interrupt service routine. Before exiting the interrupt service routine, the interrupt flag clear register BTIMx\_ICR.OV should be set to 0 to clear this flag.

After setting the run control bit BTIMx\_BCR.EN to 0 at any time, the counter stops counting immediately. When the running control bit BTMx\_BCR.EN is set to 1 again or the trigger signal is valid, the counter continues to count according to the previous setting.

The trigger start mode timing diagram is shown in the following figure:



Figure 13-9 Trigger start mode timing diagram (frequency division ratio is 2, PSC=0x01)

#### 13.3.2.4 Gated mode

Set BTIMx\_BCR.MODE to 0x03 to make BTIMx work in gated mode. In this mode, when BTMx\_BCR.EN is set to 1 and the gate control signal is valid, the counter CNT will be started to count the TCLKD signal after the internal clock PCLK is divided by the prescaler.

The gate control signal is fixed as the signal input from the external BTIM\_ETR pin. Set the POL bit field of the basic control register BTIMx\_BCR to select whether the gate control signal is a high level or a low level as an active level. You can also use the ETRFLT bit of the advanced control register BTIMx\_ACR. The domain configures whether to filter and the bandwidth of the filter.

The function block diagram of gated mode is shown in the following figure:



Figure 13-10 Gated mode block diagram

214 / 572 Rev 1.0

After the counter starts, the counter starts to count up from the initial value. When the count value reaches the reload value ARR, an overflow occurs, and the counter ARR overflow flag bit BTIMx\_ISR.OV is set by hardware. If the interrupt is enabled (set the interrupt enable register BTIMx\_IER.OV to 1), the CPU will respond to the interrupt service routine. Before exiting the interrupt service routine, the interrupt flag clear register BTIMx\_ICR.OV should be set to 0 to clear this flag.

When the running control bit BTIMx\_BCR.EN is set to 0 at any time or the gate control signal is invalid, the counter immediately stops counting. When the running control bit BTMx\_BCR.EN is set to 1 again and the gate control signal is valid, the counter continues to count according to the previous setting.

The gated mode timing diagram is shown in the following figure:

Figure 13-11 Gated mode timing diagram (PSC=0x00, POL=0x00)



#### 13.3.3 Internal cascade ITR

The timers can be cascaded to increase the bit width of the timer. For example, two 16-bit timers can be cascaded as a 32-bit timer, and the counting clock source PCLK can be 1~65535 by ITR cascade. Divide by any number in between.

The schematic diagram of BTIM two stage cascade is shown in the following figure:

GTIMX OV ITR BTIMX OV

ATIM Master mode output

Figure 13-12 Two stage cascade ITR

When used in cascade, the counting clock source of the first-level timer can be the signal input from the PLCK or external ETR pin, and the counting clock source of the subsequent-level timer is the ARR overflow signal OV of the previous-level timer or the advanced timer (ATIM) master mode output signal.

The ITR source of the timer can be selected through the timer ITR source configuration register SYSCTRL\_TIMITR. The specific configuration is shown in the following table:

| SYSCTRL_TIMITR bit field | Value | ITR source                        |
|--------------------------|-------|-----------------------------------|
|                          | 000   | Overflow signal of BTIM1          |
| BTIM3ITR                 | 001   | Overflow signal of BTIM2          |
| BTIM2ITR                 | 010   | Overflow signal of BTIM3          |
| BTIM1ITR<br>GTIM4ITR     | 011   | Overflow signal of GTIM1          |
| GTIM3ITR<br>GTIM2ITR     | 100   | Overflow signal of GTIM2          |
| GTIM21TR<br>GTIM1ITR     | 101   | Overflow signal of GTIM3          |
| ATIMITR                  | 110   | Overflow signal of GTIM4          |
|                          | 111   | Master mode output signal of ATIM |

Table 13-3 ITR source configuration

#### Caution:

The timer's ITR source cannot select its own overflow signal OV.



216 / 572

**Rev 1.0** 

#### 13.3.4 External interconnection ETR

The ETR signal source of BTIM can only be the external BTIM\_ETR pin, and all BTIMs share one ETR signal, which is configured by the GPIO multiplexing function registers (GPIOx\_AFRH and GPIOx\_AFRL), as shown in the following table:

Table 13-4 External BTIM\_ETR pin multiplexing

| ETR      | Pin       | AFR  |
|----------|-----------|------|
| DTIM FTD | PA12      | 0x02 |
| BTIM_ETR | PB11/PC13 | 0x05 |

# 13.4 Debugging support

BTIM supports to stop or continue counting in debug mode, which is set by the BTIM123 bit field of the debug status timer control register SYSCTRL\_DEBUG.

Set SYSCTRL\_DEBUG.BTIM123 to 1, then suspend the counter counting of BTIM1, BTIM2 and BTIM3 in the debug state;

Set SYSCTRL\_DEBUG.BTIM123 to 0, then the counters of BTIM1, BTIM2 and BTIM3 continue to count in the debug state.



# 13.5 Programming examples

### 13.5.1 Timer mode programming example

Step 1: Set SYSCTRL\_APBEN2.BTIM to 1, turn on the configuration clock and working clock of BTIM1, BTIM2 and BTIM3;

#### Caution:

BTIM1, BTIM2 and BTIM3 share the SYSCTRL\_APBEN2.BTIM bit.

- Step 2: Set BTIMx\_BCR.MODE to 0x00 to make BTIMx work in timer mode;
- Step 3: Configure BTMx\_BCR.ONESHOT to select single or continuous counting mode. If it is configured as 0, it is continuous counting mode, and if it is configured as 1, it is single counting mode;
- Step 4: Configure BTMx\_BCR.PSC and select the prescaler ratio;
- Step 5: Configure BTIMx\_ARR, set BTIMx count overflow time;
- Step 6: Set BTIMx\_CNT to 0x0000 for counting;
- Step 7: If you want the ARR overflow event to trigger an interrupt, set BTIMx\_IER.OV to 1;
- Step 8: Set BTIMx\_BCR.EN to 1, start BTIMx;
- Step 9: If an interrupt occurs, set BTIMx\_ICR.OV to 0 to clear the interrupt flag.

#### 13.5.2 Counter mode programming examples

#### 13.5.2.1 Count external ETR signals

To count the signals input by the external BTIM\_ETR pin, the steps are as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, and enable the configuration clock and working clock of the GPIO port corresponding to the BTIM\_ETR pin;
- Step 2: Set the relevant bits of the GPIO multiplexing function registers (GPIOx\_AFRH and GPIOx\_AFRL), and configure the source of the ETR to the required hardware pins;
- Step 3: Set the SYSCTRL\_APBEN2.BTIM bit to 1, and turn on the configuration clock and working clock of BTIM1, BTIM2 and BTIM3;

#### Caution:

### BTIM1, BTIM2 and BTIM3 share the SYSCTRL\_APBEN2.BTIM bit.

- Step 4: Configure BTIMx\_BCR.MODE to 0x01 to make BTIMx work in counter mode;
- Step 5: Configure BTIMx\_BCR.ONESHOT to select single or continuous counting mode. If it is configured as 0, it is continuous counting mode, and if it is configured as 1, it is single counting mode;
- Step 6: Configure BTIMx\_BCR.TRS to be 0, and select the counting source as the signal input from the external BTIM\_ETR pin;
- Step 7: Configure BTIMx\_ACR.ETRFLT, choose whether to filter or filter bandwidth;
- Step 8: Configure BTImx\_BCR.POL to select the ETR signal count edge. When configured as 0, the rising edge counts, and when configured as 1, the falling edge counts;
- Step 9: Configure BTMx\_BCR.PSC and select the prescaler ratio;
- Step 10: Configure BTIMx\_ARR, set BTIMx count overflow time;
- Step 11: If you want the ARR overflow event to trigger an interrupt, set BTIMx\_IER.OV to 1;
- Step 12: Set BTIMx\_BCR.EN to 1, start BTIMx;
- Step 13: If an interrupt occurs, set BTIMx\_ICR.OV to 0 to clear the interrupt flag.



219 / 572 Rev 1.0

### 13.5.2.2 Count internal ITR signals

Step 1: Set the SYSCTRL\_APBEN2.BTIM bit to 1, and turn on the configuration clock and working clock of BTIM1, BTIM2 and BTIM3;

#### Caution:

BTIM1, BTIM2 and BTIM3 share the SYSCTRL APBEN2.BTIM bit.

- Step 2: Configure BTIMx\_BCR.MODE to 0x01, select BTIMx to work in counter mode;
- Step 3: Configure BTMx\_BCR.ONESHOT to select single or continuous counting mode. If it is configured as 0, it is continuous counting mode, and if it is configured as 1, it is single counting mode;
- Step 4: Configure BTImx\_BCR.TRS to 1, select the count signal from the internal ITR signal;
- Step 5: Configure the SYSCTRL\_TIMITR register and select the ITR source of the corresponding timer;
- Step 6: Configure BTIMx\_BCR.PSC and select the prescaler ratio;
- Step 7: Configure BTIMx\_ARR, select BTIMx count overflow time;
- Step 8: If you want the ARR overflow event to trigger an interrupt, configure BTIMx\_IER.OV to 1;
- Step 9: Set BTIMx\_BCR.EN to 1, start BTIMx;
- Step 10: If an interrupt occurs, set BTIMx\_ICR.OV to 0 to clear the interrupt flag.

### 13.5.3 Trigger start mode programming example

Step 1: Set the SYSCTRL\_APBEN2.BTIM bit to 1, and turn on the configuration clock and working clock of BTIM1, BTIM2 and BTIM3;

#### Caution:

BTIM1, BTIM2 and BTIM3 share the SYSCTRL APBEN2.BTIM bit.

- Step 2: Configure BTIMx\_BCR.TRS and select the trigger source. When configured as 0, the trigger signal comes from the external BTIM\_ETR pin input signal; when configured as 1, the trigger signal comes from the internal cascaded ITR signal;
- **Step 3:** If the trigger signal is input from the BTIM\_ETR pin, BTIMx\_ACR.ETRFLT can be configured to select whether to filter or filter bandwidth;
- Step 4: If the trigger signal is input from the BTIM\_ETR pin, configure BTIMx\_BCR.POL and select the ETR signal to trigger the edge. If it is configured as 0, the rising edge counting starts, and if it is configured as 1, the falling edge counting starts;
- Step 5: Configure BTMx\_BCR.PSC and select the prescaler ratio;
- Step 6: Configure BTMx\_BCR.ONESHOT to select single or continuous counting mode. If it is configured as 0, it is continuous counting mode, and if it is configured as 1, it is single counting mode;
- Step 7: If you want the trigger event to trigger an interrupt, set BTIMx\_IER.IT to 1;
- Step 8: If you want the ARR overflow event to cause an interrupt, set BTIMx\_IER.OV to 1;
- Step 9: Configure BTIMx\_ARR, select BTIMx count overflow time;
- Step 10: Configure BTIMx\_BCR.MODE to 0x10, select BTIMx to work in trigger start mode;
- Step 11: Determine whether to write 1 to BTIMx\_BCR.EN as needed to immediately start BTIMx for counting;
- Step 12: If an interrupt occurs, write 0 to the corresponding bit of the BTIMx\_ICR register to clear the interrupt flag according to the event of the interrupt.

#### Caution:

Set the polarity of the trigger signal first, and then set the timer mode, otherwise it will cause false triggering.



220 / 572 Rev 1.0

### 13.5.4 Gated mode programming example

The signal input from the external BTIM\_ETR pin is used as the gate control signal to control the count of the counter. The operation steps are as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, and enable the configuration clock and working clock of the GPIO port corresponding to the BTIM\_ETR pin;
- Step 2: Set the relevant bits of the GPIO multiplexing function registers (GPIOx\_AFRH and GPIOx\_AFRL), and configure the source of the ETR to the required hardware pins;
- Step 3: Set the corresponding bit of the GPIOx\_ANALOG register of the corresponding GPIO pin to 0, and configure it as a digital function;
- Step 4: Set the corresponding bit of the GPIOx\_DIR register of the corresponding GPIO pin to 1, and configure the port as an input;
- Step 5: Set the SYSCTRL\_APBEN2.BTIM bit to 1, and turn on the configuration clock and working clock of BTIM1, BTIM2 and BTIM3;

#### Caution:

### BTIM1, BTIM2 and BTIM3 share the SYSCTRL\_APBEN2.BTIM bit.

- Step 6: Configure BTIMx\_BCR.MODE to 0x03, select BTIMx to work in gated mode;
- Step 7: Configure BTIMx\_ACR.ETRFLT, choose whether to filter or filter bandwidth;
- Step 8: Configure BTImx\_BCR.POL to select ETR signal polarity. When configured as 0, the gate control mode is active at high level, and when configured as 1, the gated mode is active at low level;
- Step 9: Configure BTMx\_BCR.PSC and select the prescaler ratio;
- Step 10: Configure BTIMx\_BCR.ONESHOT to select single or continuous counting mode. When configured as 0, it is continuous counting mode, and when configured as 1, it is single counting mode;
- Step 11: If you want the ARR overflow event to trigger an interrupt, configure BTIMx\_IER.OV to 1;
- Step 12: Configure the BTIMx\_ARR register and select the BTIMx count overflow time;
- Step 13: Set BTIMx\_BCR.EN to 1, start BTIMx;
- Step 14: If an interrupt occurs, set BTIMx\_ICR.OV to 0 to clear the interrupt flag.



221 / 572 Rev 1.0

# 13.6 List of registers

BTIM1 base address: BTIM1\_BASE = 0x4001 4800 BTIM2 base address: BTIM2\_BASE = 0x4001 4900 BTIM3 base address: BTIM3\_BASE = 0x4001 4A00

Table 13-5 List of BTIM registers

| Register name | Register address  | Register description          |
|---------------|-------------------|-------------------------------|
| BTIMx_ARR     | BTIMx_BASE + 0x00 | Reload register               |
| BTIMx_CNT     | BTIMx_BASE + 0x04 | Count register                |
| BTIMx_ACR     | BTIMx_BASE + 0x0C | Advanced control register     |
| BTIMx_BCR     | BTIMx_BASE + 0x10 | Basic control register        |
| BTIMx_IER     | BTIMx_BASE + 0x14 | Interrupt enable register     |
| BTIMx_ISR     | BTIMx_BASE + 0x18 | Interrupt flag register       |
| BTIMx_ICR     | BTIMx_BASE + 0x1C | Interrupt flag clear register |
| BTIMx_DMA     | BTIMx_BASE + 0x20 | DMA trigger register          |
| BTIMx_PSC     | BTIMx_BASE + 0x24 | Prescaler register            |

# 13.7 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

# 13.7.1 BTIMx\_BCR basic control register

Address offset: 0x10 Reset value: 0x0000 0000

| Bit field | Name    | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------|---------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7      | RFU     | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6         | TOGEN   | RW         | TOG pin output enable control 0: TOGP, TOGN output level is 0 1: TOGP, TOGN output signals with opposite levels                                                                                                                                                                                                                                                                                                                                 |
| 5         | ONESHOT | RW         | Single/continuous counting mode control 0: Continuous counting mode 1: Single counting mode                                                                                                                                                                                                                                                                                                                                                     |
| 4         | POL     | RW         | ETR signal polarity selection for external pin input  0: ETR is positive (the rising edge of trigger mode is valid, and the gated mode is valid at high level)  1: ETR is reversed (the falling edge of trigger mode is valid, and the gated mode is valid at low level)                                                                                                                                                                        |
| 3         | TRS     | RW         | Trigger source selection 0: The signal input by the ETR pin 1: ITR, see section 13.3.3 Internal cascade ITR                                                                                                                                                                                                                                                                                                                                     |
| 2:1       | MODE    | RW         | Basic timing mode configuration 00: Timer mode, counting clock source is PCLK 01: Counter mode, counting clock source is TRS signal 10: 10: Trigger start mode, the counting clock source is PCLK, and the TRS signal triggers the counter to start 11: Gated mode, the counting clock source is PCLK, and the ETR pin input signal is used as gate control Caution: When in counter mode, the BTIMx_PSC register value must be greater than 0. |
| 0         | EN      | RW         | Timer running control 0: Timer stopped 1: Timer running                                                                                                                                                                                                                                                                                                                                                                                         |

# 13.7.2 BTIMx\_ACR advanced control register

Address offset: 0x0C Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7      | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6:4       | ETRFLT | RW         | The ETR pin input signal filtering configuration; the sampling clock is PCLK or PCLK frequency division, the number of sampling points is N, and N consecutive levels are valid.  000: no filter  001: F <sub>sample</sub> = PCLK, N=2  010: F <sub>sample</sub> = PCLK, N=4  011: F <sub>sample</sub> = PCLK, N=6  100: F <sub>sample</sub> = PCLK/4, N=4  101: F <sub>sample</sub> = PCLK/4, N=6  110: F <sub>sample</sub> = PCLK/16, N=4  111: F <sub>sample</sub> = PCLK/16, N=6 |
| 3:0       | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                         |

# 13.7.3 BTIMx\_PSC Prescaler register

Address offset: 0x24 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                            |
|-----------|------|------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value                                                                                    |
| 15:0      | ARR  | RW         | Prescaler value When the count clock is PCLK: TCLKD = TCLK / (PSC + 1) When the count clock is TRS: TCLKD = TCLK / PSC, PSC > 0 |

## 13.7.4 BTIMx\_ARR reload register

Address offset: 0x00 Reset value: 0x0000 FFFF

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | ARR  | RW         | Timer reloads value                          |



## 13.7.5 BTIMx\_CNT count register

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | CNT  | RW         | Timer count value                            |

# 13.7.6 BTIMx\_IER interrupt enable register

Address offset: 0x14 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                               |
|-----------|------|------------|--------------------------------------------------------------------------------------------------------------------|
| 31:3      | RFU  | -          | Reserved bits, please keep the default value                                                                       |
| 2         | ТОР  | RW         | Counter TOP overflow interrupt enable control 0: TOP overflow interrupt disabled 1: TOP overflow interrupt enabled |
| 1         | TI   | RW         | Trigger interrupt enable control 0: Trigger interrupt disabled 1: Trigger interrupt enabled                        |
| 0         | OV   | RW         | Counter ARR overflow interrupt enable control 0: ARR overflow interrupt disabled 1: ARR overflow interrupt enabled |

# 13.7.7 BTIMx\_ISR interrupt flag register

Address offset: 0x18 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                              |
|-----------|------|------------|---------------------------------------------------------------------------------------------------|
| 31:3      | RFU  | -          | Reserved bits, please keep the default value                                                      |
| 2         | ТОР  | RO         | Counter TOP overflow flag 0: The counter has not TOP overflowed 1: The counter has TOP overflowed |
| 1         | TI   | RO         | Trigger flag  0: No trigger event occurred  1: The trigger event has occurred                     |
| 0         | OV   | RO         | Counter ARR overflow flag 0: The counter has not ARR overflowed 1: The counter has ARR overflowed |



# 13.7.8 BTIMx\_ICR interrupt flag clear register

Address offset: 0x1C Reset value: 0x0000 0007

| Bit field | Name | Permission | Function description                                                                          |
|-----------|------|------------|-----------------------------------------------------------------------------------------------|
| 31:3      | RFU  | -          | Reserved bits, please keep the default value                                                  |
| 2         | ТОР  | R1W0       | Counter TOP overflow flag cleared<br>W0: Counter TOP overflow flag cleared<br>W1: No function |
| 1         | TI   | R1W0       | Trigger flag cleared<br>W0: Trigger flag cleared<br>W1: No function                           |
| 0         | OV   | R1W0       | Counter ARR overflow flag cleared<br>W0: Counter ARR overflow flag cleared<br>W1: No function |

# 13.7.9 BTIMx\_DMA DMA trigger register

Address offset: 0x20 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                    |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                            |
| 1         | TRS  | RW         | Synchronous trigger DMA enable control when the counter is triggered to start  0: No function  1: DMA is triggered synchronously when the counter is triggered to start |
| 0         | OV   | RW         | Counter ARR overflow triggers DMA enable control 0: No function 1: Counter ARR overflow triggers DMA                                                                    |

# 14 General-purpose timer (GTIM)

#### 14.1 Overview

CW32W031 integrates two general-purpose timers (GTIM), each GTIM is completely independent and has the same function, each contains a 16-bit automatic reload counter and is driven by a programmable prescaler. GTIM supports 4 basic working modes: timer mode, counter mode, trigger start mode and gate control mode. Each group has 4 independent capture/compare channels, which can measure the pulse width of input signals (input capture) or generate output waveforms (output compare and PWM).

#### 14.2 Main features

- Programmable prescaler supports 1,2,3,4,···,65536 frequency division
- 16-bit auto-reload counter
- Supports single counting mode and continuous counting mode
- Counting function for internal ITR or ETR input signal
- Internal ITR or ETR input signal triggers start counting
- 4 independent input capture and output compare channels
- Supports incremental (quadrature) encoders for positioning
- Overflow event triggers digital output level transition
- Internal cascade ITR and on-chip peripheral interconnect ETR
- Interrupt/DMA generated when various events occur
  - Counter count overflow
  - The counter is triggered to start
  - Input capture
  - Output compare



# 14.3 Functional description

## 14.3.1 Functional block diagram

The functional block diagram of GTIM is shown in the following figure:

CR0.TOGEN **PSC** CR0.TRS **PCLK** -⊠ TOGP TOG TCLK Prescaler /1, 2, ..., /65536 Reload register ARR ITR Control 1 TOGN TRS TCLKD 0 ETR pin RXD signal of UART1 -٥٧ Trig ARR RXD signal of UART2 -IFR OV overflow Polarity Edge detection 16-bit up counter RXD signal of UART3 -**FILTER** selection ĊNT VC1 output signal -VC2 output signal -Gate UD overflow ETR.ETRFLT CR0.POL LVD output signal interrupt Trigger interrupt IER.TI Polarity Edge Output CH1 FILTER CH1 capture comparison ►X CH1 selectiór detectio Polarity Edge detection Output control CH2 FILTER CH2 capture comparison ► CH2 selection Polarity Edge Output СНЗ ⊠-FILTER CH3 capture comparison **⊳**⊠ СНЗ selection detection control Polarity Edge Output ►⊠ CH4 CH4 FILTER CH4 capture comparison

Figure 14-1 GTIM functional block diagram

#### 14.3.1.1 Prescaler

The prescaler coefficient is configured by the GTIMx\_PSC register, and the specific frequency division coefficient is related to the counter clock source TCLK. When the counter clock source is PCLK, the frequency division coefficient is PSC+1; when the counter clock source is TRS, the frequency division coefficient is PSC (PSC>0).

It is allowed to modify GTIMx\_PSC during the timer operation, but the new prescale factor will not take effect immediately. When the timer overflows or the running control bit GTIMx\_CR0.EN changes from 0 to 1, the new prescale factor takes effect.

### 14.3.1.2 Counting unit

The core component of the counting unit is a 16-bit counter CNT and a 16-bit automatic reload register ARR.

It is allowed to modify the reload register ARR while the timer is running, and the value of ARR will take effect immediately. The correct counting range of the counter CNT is between 0 and the reload value ARR. Therefore, when setting the reload register ARR, ensure that the value of CNT is less than the set value of the ARR register.

The counter can work in single count or continuous count mode, which is selected by the ONESHOT bit field of the control register GTIMx\_CR0.

## Single counting mode

Set GTIMx\_CR0.ONESHOT to 1 to make the timer work in single counting mode. Set GTIMx\_CR0.EN to 1 to enable GTIMx, and the counter CNT counts up under the drive of the TCLKD clock. When the count value reaches the reload value ARR, an overflow signal OV is generated (the overflow signal OV remains for one PCLK cycle, and then automatically cleared), and the counter stops counting, and GTIMx\_CR0.EN is automatically reset by hardware.

The following figure is an example of single counting mode:



Figure 14-2 Single counting mode (PSC=0x01, ARR=0xFC)

### Continuous counting mode

Set GTIMx\_CR0.ONESHOT to 0 to make the timer work in continuous counting mode. Set GTIMx\_CR0.EN to 1 to enable GTIMx, and the counter CNT counts up under the drive of the TCLKD clock. When the count value reaches the reload value ARR, an overflow signal OV is generated (the overflow signal OV remains for one PCLK cycle, and then automatically cleared). When the count value changes from ARR to 0, the counter ARR overflow flag bit GTIMx\_ISR.OV is set by hardware, the counter starts to count up in the next cycle, and stops counting until GTIMx\_CR0.EN is set to 0.

The following figure is an example of continuous counting mode:

Figure 14-3 Continuous counting mode (PSC=0x00, ARR=0xFC)

### **Encoding counting mode**

When the register bit GTIMx\_CR0.ENCMODE is not 0x00, the counter works in the encoding counting mode. At this time, the counting direction of the counter is specified by the hardware, which can count up or count down. The counter CNT is automatically incremented or decremented by 1 according to GTIMx\_ISR. DIR. Whenever counting up to ARR, the counter will generate an overflow signal OV, and automatically start counting up from 0 again; whenever counting down to 0, the counter will generate an underflow signal UD, and start counting down from 0xFFFF.

#### 14.3.1.3 Input control unit

The ETR input signal and the four compare input signals CH1~CH4 all have their own input control units. The input control unit consists of filters, polarity selection and edge detection.

#### Filter

The filter adopts a digital filtering method to sample the input signal at a certain frequency. When N consecutive samples of the same level are obtained, the signal is valid, otherwise the signal is invalid, so as to filter out high-frequency clutter signals.

#### Caution:

Since the hardware samples the input signal with the PCLK clock or the frequency division of the PCLK clock, the input signal whose frequency is higher than half of the actual sampling frequency may be missed.

The filter of the ETR input signal is configured by the external trigger control register GTIMx\_ETR.ETRFLT to configure the sampling clock frequency and the number of sampling points. The filter of the comparison input CHy is configured by the control register GTIMx\_CR1.CHyFLT to configure the sampling clock frequency and the number of sampling points (y=1, 2, 3, 4).

#### Polarity selection

Polarity selection is used to select whether to invert the input signal. The ETR input signal is selected to be inverted through the control register GTIMx\_CR0.POL and applied to the gated mode. The input signal of the compare input CHy is selected by the control register GTIMx\_CR1.CHyPOL whether to invert or not.

#### **Edge detection**

Edge detection is used to detect the transition of the input signal and whether the direction of the transition is rising or falling.

#### 14.3.1.4 Capture compare channel

The capture compare channel consists of a compare capture register and a comparator, as shown in the following figure:

Capture event

Capture event

Comparators

CNT<CCRy

CNT=CCRy

CNT>CCRy

Figure 14-4 Schematic diagram of the capture compare channel

When the input is captured, once the corresponding channel has a capture event, the current value of the counter CNT is immediately transferred to the compare capture register CCRy to save, if the corresponding capture compare interrupt is enabled, an interrupt request will be generated.

When the output is compared, the value of the counter CNT is always compared with the value of the compare capture register CCRy. When the compare result is the set requirement, a signal can be generated to control the output to change. An interrupt request will be generated if the corresponding capture compare interrupt is enabled.

#### 14.3.1.5 Output control unit

The output control unit is used to control the waveform of the output port when comparing and matching. The compare output mode of the corresponding channel is configured through the CCyM bit field of the compare capture control register GTIMx\_CMMR. For the specific configuration and application, see section *14.3.4 Output compare function*.

### 14.3.1.6 Flip output unit

The flip output unit can control the external GTIMx\_TOGP and GTIMx\_TOPN pins to output the toggle signal through the ARR overflow signal OV.

When GTIMx\_CR0.TOGEN is set to 0, both GTIMx\_TOGP and GTIMx\_TOPN pins output low level.

When GTIMx\_CR0.TOGEN is set to 1, the GTIMx\_TOGP and GTIMx\_TOPN pins output signals with opposite levels (the default level of GTIMx\_TOGP is high); when the counter ARR overflows (GTIMx\_ISR.OV is 1), the GTIMx\_TOGP and GTIMx\_TOPN pins output The level will flip.

The following figure shows the schematic diagram of GTIMx\_TOGP and GTIMx\_TOPN pin level flip output in continuous counting mode:

Figure 14-5 Schematic diagram of level flip output (continuous counting mode, ARR=0x0B)



The TOGP/TOGN pins supported by GTIM are shown in the following table:

Table 14-1 GTIM flip output pins

| TOGP/TOGN  | Pin  | AFR  |
|------------|------|------|
| GTIM1_TOGP | PB12 | 0x06 |
| GTIM1_TOGN | PB07 | 0x06 |
| GTIM2_TOGP | PB12 | 0x01 |
|            | PF00 | 0x06 |
| GTIM2_TOGN | PF01 | 0x06 |

### 14.3.2 Basic operating modes

GTIM supports 4 basic operating modes: timer mode, counter mode, trigger start mode and gated mode. Configured by the MODE bit field of the control register GTIMx\_CR0.

| . ~                      |                      |                      |                                                                                       |
|--------------------------|----------------------|----------------------|---------------------------------------------------------------------------------------|
| General-purpose<br>timer | MODE bit field value | Basic operating mode | Description                                                                           |
|                          | 00                   | Timer mode           | The clock source is PCLK                                                              |
|                          | 01                   | Counter mode         | The counting source is TRS signal                                                     |
| GTIMx_CR0 (x=1,2)        | 10                   | Trigger start mode   | The clock source is PCLK, and the TRS signal triggers the counter to start            |
|                          | 11                   | Gated mode           | The clock source is PCLK, and the ETR input signal is used as the gate control signal |

Table 14-2 GTIM basic operating modes

#### 14.3.2.1 Timer mode

Set the MODE bit field of the control register GTIMx\_CR0 to 0x00 to make GTIMx work in timer mode. In this mode, the counter clock source is the internal system clock PCLK, which is divided by the prescaler to obtain the count clock TCLKD to drive the counter CNT to count. The function block diagram of timer mode is shown in the following figure:



Figure 14-6 Timer mode block diagram

In practical applications, the frequency of the system clock PCLK is known. By setting the prescaler coefficient PSC reasonably, the clock with a fixed duration can be counted, in conjunction with the setting of the reload value ARR and the use of the counter ARR overflow interrupt flag bit, you can accurately obtain a specific duration, so as to achieve the purpose of timing. The following figure is the timing waveform of the timer in continuous counting mode:



Figure 14-7 Continuous counting, timer mode waveform

Timing time T calculation formula:

$$T = ((PSC+1)/PCLK) \times (ARR+1)$$

Where, PCLK is the counter clock source, PSC is the prescaler coefficient, and ARR is the reload value.

#### Example:

When the frequency of the counter clock source PCLK is 24MHz, the timing is required to be 10ms. If the prescaler coefficient PSC is set to 0xFF, calculate:

$$T = 10ms = ((255+1)/24MHz) \times (ARR+1)$$

then

$$ARR = 936.5$$

That is, the reload value ARR can be set to 937(0x3A9).

#### 14.3.2.2 Counter mode

Set the MODE bit field of the control register GTIMx\_CR0 to 0x01 to make GTIMx work in counter mode. In this mode, the counter clock source is the TRS signal, and the source of the TRS can be selected as the internal ITR signal or the ETR input signal through the TRS bit field of the control register GTIMx\_CR0.

When setting the TRS bit field of the control register GTIMx\_CR0 to 0, the source of the TRS signal is the ETR input signal. By setting the POL bit field of the control register GTIMx\_CR0, you can choose to count on the rising or falling edge of the ETR input signal; when setting the control register When the TRS bit field of the register GTIMx\_CR0 is 1, the source of the TRS signal is the internal ITR signal, and the ITR signal is the output signal of other timers (refer to *Table 14-19 ITR source configuration*).

The functional block diagram of counter mode is shown in the following figure:



Figure 14-8 Counter mode block diagram

When the EN bit field of the control register GTIMx\_CR0 is set to 1, the counter accumulates the counted TCLKD signal after frequency division, overflows after counting to the ARR value, and starts counting from 0 again. For the specific register configuration process in counter mode, please refer to section *14.6 Programming examples*.

### 14.3.2.3 Trigger start mode

Set the MODE bit field of the control register GTIMx\_CR0 to 0x02 to make GTIMx work in trigger start mode. In this mode, the counting clock of the counter is the signal TCLKD after the system clock PCLK is divided by the prescaler. When GTIMx\_CR0.EN is set to 1 or the trigger signal is valid, the counter will start to count.

The source of the trigger signal TRS can be the internal ITR signal or the ETR input signal, which is selected by the TRS bit field of the control register GTIMx\_CR0. When the TRS bit field of the control register GTIMx\_CR0 is set to 0, the source of the TRS signal is the ETR input signal. By setting the POL bit field of the control register GTIMx\_CR0, the ETR input signal can be selected to be valid on the rising edge or falling edge; when setting the control register GTIMx\_CR0 When the TRS bit field is 1, the source of the TRS signal is the internal ITR signal, and the ITR signal is the output signal of other timers (refer to *Table 14-19 ITR source configuration*). The function block diagram of trigger start mode is shown in the following figure:



Figure 14-9 Trigger start mode block diagram

When a valid trigger signal is detected, the following effects occur:

- 1. GTIMx\_CR0.EN is set by hardware;
- 2. Trigger flag bit GTIMx\_ISR.TI is set by hardware;
- 3. The counter starts and starts counting.

After the counter is started, the counter starts to count up from the initial value. When the software sets GTIMx\_CR0.EN to 0, the counter suspends counting, and sets GTIMx\_CR0.EN to 1 again or when the trigger signal TRS is a valid transition, the counter resumes counting and generates a Trigger sign. The following figure shows an example of the trigger start mode timing diagram:

**PCLK** CR0.EN Software write 1 Software write 0 Hardware set 1 CR0.TRS  $\mathsf{TCLKD}$ Count register 0x52 0x53 0x54 0x55 0x56 0x57 CNT ISR.TI -ICR.TI software writes 0

Figure 14-10 Timing diagram of trigger start mode (frequency division ratio is 2, PSC=0x01)

#### 14.3.2.4 Gated mode

Set the MODE bit field of the control register GTIMx\_CR0 to 0x03 to make GTIMx work in gated mode. In this mode, the counting clock of the counter is the signal TCLKD after the system clock PCLK is divided by the prescaler. When GTIMx\_CR0.EN is set to 1 and the gate control signal is valid, the counter will start to count.

The source of the gate control signal is the ETR input signal. The source of the ETR signal can be the external GTIMx\_ETR pin or other on-chip peripherals, which can be selected through the general-purpose timer ETR source configuration register SYSCTRL\_GTIMETR (see section *14.3.7 On-chip peripheral interconnect ETR*). By setting the POL bit field of the control register GTIMx\_CR0, it is possible to select whether the polarity of the ETR signal is reversed, so as to select whether the effective polarity of the gate control signal is a high level or a low level

The function block diagram of gated mode is shown in the following figure:



Figure 14-11 Gated mode block diagram

The following figure is used to illustrate that in the gated mode, when the gated level is an invalid level, even if GTIMx\_CR0.EN is set to 1, the counter will not count, only when the gated level is a valid level, the counter will count. Once the gated level is invalid, the counting will be suspended immediately.



Figure 14-12 Timing diagram of gated mode (frequency division ratio is 1, PSC=0x00, gated is active high, POL=0x00)

#### 14.3.3 Input capture function

#### 14.3.3.1 Input capture

When the signal on the capture compare channel CHy transitions (rising edge or falling edge), the hardware automatically stores the value of the current count register GTIMx\_CNT in the compare capture register GTIMx\_CCRy of the corresponding channel to complete a capture. The input capture function can be used to measure pulse width or frequency. Its functional block diagram is shown in the following figure:

CHy Filter Polarity selection Edge detection CNT

Figure 14-13 Input capture mode block diagram

The conditions for triggering capture on each channel are determined by the compare capture control register GTIMx\_CMMR, as shown in the following table:

Table 14-3 Input capture mode configuration

When a capture occurs, the channel CHy compare capture interrupt flag GTIMx\_ISR.CCy is set by hardware. If the interrupt is enabled (set the interrupt enable register GTIMx\_IER.CCy to 1), the CPU will respond to the interrupt service routine. Before exiting the interrupt service routine, the interrupt flag clear register GTIMx\_ICR.CCy should be set to 0 to clear this flag.

### 14.3.3.2 Input capture sources

The input capture source of GTIM can be external GTIMx\_CHy pin or other on-chip peripherals, which can be configured through the general-purpose timer input capture source configuration register SYSCTRL\_GTIMxCAP.

When SYSCTRL\_GTIMxCAP.CHy is 0x00, the external input port to which the capture signal is input is configured by the GPIO multiplexing function registers (GPIOx\_AFRH and GPIOx\_AFRL).

When SYSCTRL\_GTIMxCAP.CHy is 0x01~0x06, the input capture signal comes from other on-chip peripherals, as shown in the following table:

Table 14-4 General-purpose timer input capture sources

| SYSCTRL_GTIMxCAP bit field | Value | Input capture source of GTIMx           |
|----------------------------|-------|-----------------------------------------|
|                            | 000   | Configured by GPIOx_AFRH and GPIOx_AFRL |
|                            | 001   | RXD signal of UART1                     |
| СНу                        | 010   | RXD signal of UART2                     |
|                            | 011   | RXD signal of UART3                     |
|                            | 100   | Compare output signal of VC1            |
|                            | 101   | Compare output signal of VC2            |
|                            | 110   | LVD output signal                       |

Under this configuration, the interconnection of external input can be realized inside the chip. For example, the RXD signal of the UART is used as the input capture source, and the automatic detection of the UART baud rate can be realized.

#### 14.3.4 Output compare function

#### 14.3.4.1 Output compare

In the output compare mode, the value of the current count register GTIMx\_CNT is compared with the value of the compare capture register GTIMx\_CCRy of the corresponding channel CHy. When the two match, the compare capture channel CHy can output a high level or a low level and generate a compare interrupt at the same time. The output compare function can be used to control an output waveform or indicate that a given time has arrived. Its functional block diagram is shown in the following figure:

CCRy
ISR.CCy set 1
Comparators
Match
CMMR.CCyM
CNT

Figure 14-14 Output compare mode block diagram

The output action of the CHy pin depends on the CCyM bit field of the compare capture control register GTIMx\_CMMR, as shown in the following table:

| General-purpose<br>timer    | Channel CHy | CCyM bit field<br>value          | Compare mode configuration                       |
|-----------------------------|-------------|----------------------------------|--------------------------------------------------|
| GTIMx_CMMR CCyM (y=1,2,3,4) |             | 1000                             | Force CHy to output low level                    |
|                             |             | 1001                             | Force CHy to output high level                   |
|                             | ССуМ        | 1010                             | CHy is set to 0 on compare match                 |
|                             | 1011        | CHy is set to 1 on compare match |                                                  |
|                             |             | 1110                             | PWM positive output (CNT >= CCR output high)     |
|                             |             | 1111                             | PWM reverse output (CNT < CCR output high level) |

Table 14-5 Output compare mode configuration

When the value of the CCyM bit of the GTIMx\_CMMR register is 0x0A, when a compare match occurs, the CHy pin outputs a low level, and the CCy bit of the GTIMx\_ISR register is set to 1.

When the value of the CCyM bit in the GTIMx\_CMMR register is 0x0B, when a compare match occurs, the CHy pin outputs a high level, and the CCy bit in the GTIMx\_ISR register is set to 1.

The following figure shows two compare output modes: set low level and set high level, where CCRy is preset to 0x003A.



Figure 14-15 Two compare output modes

### 14.3.4.2 Force output function

In forced output mode, the output compare signal can be forced to a high or low state directly by software, without depending on the compare result of the compare capture register GTIMx\_CCRy and the count register GTIMx\_CNT.

Set the corresponding CCyM bit field in the GTIMx\_CMMR register to 0x8 to force the CHy channel to output a low level. Set the corresponding CCyM bit field in the GTIMx\_CMMR register to 0x9 to force the CHy channel to output a high level.

In this mode, the comparison between the GTIMx\_CCRy register and the counter GTIMx\_CNT is still in progress, the corresponding flags are also modified, and corresponding interrupts and DMA requests are also generated.

#### 14.3.4.3 PWM output function

Pulse width modulation (PWM) mode can generate a signal whose frequency is determined by the reload register GTIMx\_ARR and the duty cycle is determined by the compare capture register GTIMx\_CCRy.

Writing 0xE or 0xF to the CCyM bits in the GTIM\_CCMR register can independently set each CHy output channel to generate a PWM.

Set GTIMx\_CMMR.CCyM to 0xE, when GTIMx\_CNT>=GTIMx\_CCRy, the CHy channel outputs a high level, otherwise it outputs a low level.

#### Caution:

If the compare value in GTIMx\_CCRy is greater than the value of the reload register GTIMx\_ARR, the CHy channel output remains low;

If the compare value in GTIMx\_CCRy is 0, the CHy channel output remains high.

Set GTIMx\_CMMR.CCyM to 0xF, when GTIMx\_CNT<GTIMx\_CCRy, the CHy channel outputs a high level, otherwise it outputs a low level.

#### Caution:

If the compare value in GTIMx\_CCRy is greater than the value of the reload register GTIMx\_ARR, the CHy channel output remains high;

If the compare value in GTIMx\_CCRy is 0, the CHy channel output remains low.

The following figure is an example of PWM waveform when GTIMx\_CMMR.CCyM is 0xE and GTIMx\_ARR is 0x08:



Figure 14-16 PWM waveform example

### 14.3.5 Encoding counting mode

The capture/compare channel CH1 and CH2 pins of GTIM can be connected with the encoder as the interface of the quadrature encoder. When the ENCMODE bit field of the control register GTIMx\_CR0 is set to a value other than 0x00, the GTIMx works in the quadrature encoding mode, and the count clock of the counter is input by the CH1 and CH2 pins.

GTIM supports 3 encoding counting modes: set GTIMx\_CR0.ENCMODE to 0x01, the counter will only count on the edge of CH1; set GTIMx\_CR0.ENCMODE to 0x02, the counter will only count on the edge of CH2; set GTIMx\_CR0.ENCMODE to 0x03, the counter will count at the edges of ch1 and CH2 at the same time.

Through the CH1POL and CH2POL bit fields of the control register GTIMx\_CR1, you can select the polarity of the channel CH1 and CH2 input signals sent to the internal circuit. The input filters of channels CH1 and CH2 can be configured through the CH1FLT and CH2FLT bit fields of the control register GTIMx\_CR1.

Setting GTIMx\_CR0.EN to 1 starts the counter, which will be driven by each valid transition of the filtered and polarity controlled input signals of the channel CH1 and CH2 pins. According to the transition sequence of the two input signals, a count pulse and a direction signal are generated. The encoder's current counting direction flag GTIMx\_ISR.DIR is automatically set by hardware. When the counting direction is changed, the encoder counting direction change interrupt flag bit GTIMx\_ISR.DIRCHANGE will be set by hardware. If the interrupt is enabled (set GTIMx\_IER.DIRCHANGE to 1), the CPU will respond to the interrupt service routine. Before exiting the interrupt service routine, GTIMx\_ICR.DIRCHANGE should be set to 0 to clear this flag.

The relationship between counting direction and encoder signal is shown in the following table:

|        | Signa | l level | CH1          |              | CH2          |              |
|--------|-------|---------|--------------|--------------|--------------|--------------|
|        | CH2   | CH1     | Rising       | Falling      | Rising       | Falling      |
| Mode 1 | High  | -       | Downcounting | Upcounting   | No counting  | No counting  |
| Mode 1 | Low   | -       | Upcounting   | Downcounting | No counting  | No counting  |
| Mode 2 | -     | High    | No counting  | No counting  | Upcounting   | Downcounting |
| Mode 2 | -     | Low     | No counting  | No counting  | Downcounting | Upcounting   |
| Mode 3 | High  | High    | Downcounting | Upcounting   | Upcounting   | Downcounting |
| wode 3 |       | Low     | Upcounting   | Downcounting | Downcounting | Upcounting   |

Table 14-6 Relationship between counting direction and encoder signal

The third signal output by the encoder represents the mechanical zero point, which can be connected to the CH3 channel. Through the ENCRELOAD bit field of the control register GTIMx\_CR0, you can choose to reload the value of the counter CNT on the rising or falling edge. You can also choose to reset the value of the counter CNT on the rising or falling edge through the ENCRESET bit field of the control register GTIMx\_CR0 (the reset operation makes the value of the CNT register is 0x0000).

The following figure is an example of the operation of the encoding counting mode, showing the generation and direction control of the count signal. It also shows how input jitter is suppressed when dual edge is selected; jitter can occur when the sensor is positioned close to a transition point.



Figure 14-17 Example of counter operation in encoder mode

#### 14.3.6 Internal cascade ITR

The timer can be cascaded through the ITR signal, thereby expanding the counting range of the timer, and it can also divide the count clock source PCLK by any number between 1 and 65535.

The source of the cascaded input ITR of GTIM is BTIM, the overflow signal of GTIM and the main mode output signal of ATIM, which can be selected by the timer ITR source configuration register SYSCTRL\_TIMITR. The specific configuration is shown in the following table:

SYSCTRL\_TIMITR bit field Value ITR source 000 Overflow signal of BTIM1 BTIM3ITR 001 Overflow signal of BTIM2 BTIM2ITR 010 Overflow signal of BTIM3 BTIM1ITR GTIM2ITR 011 Overflow signal of GTIM1 GTIM1ITR 100 Overflow signal of GTIM2 **ATIMITR** 111 Master mode output signal of ATIM

Table 14-7 ITR source configuration

#### Caution:

The timer's ITR source cannot select its own overflow signal OV.



247 / 572

## 14.3.7 On-chip peripheral interconnect ETR

The source of the ETR signal of GTIM can be the external GTIMx\_ETR pin or other on-chip peripherals, which can be selected through the general-purpose timer ETR source configuration register SYSCTRL\_GTIMETR.

When SYSCTRL\_GTIMETR.GTIMXETR is 0x00, the external input port of the ETR signal is configured by the GPIO multiplexing function registers (GPIOx\_AFRH and GPIOx\_AFRL), as shown in the following table:

Table 14-8 External GTIMx\_ETR pin multiplexing

| ETR       | Pin  | AFR  |
|-----------|------|------|
| GTIM1_ETR | PB02 | 0x06 |
| GTIM2_ETR | PA05 | 0x01 |
|           | PA04 | 0x06 |
|           | PA00 | 0x07 |

When SYSCTRL\_GTIMETR.GTIMXETR is 0x01~0x06, the ETR signal comes from other on-chip peripherals to realize the interconnection between on-chip peripherals, as shown in the following table:

Table 14-9 ETR sources for GTIMx

| SYSCTRL_GTIMETR.GTIMxETR | ETR source for GTIMx                    |
|--------------------------|-----------------------------------------|
| 000                      | Configured by GPIOx_AFRH and GPIOx_AFRL |
| 001                      | RXD signal of UART1                     |
| 010                      | RXD signal of UART2                     |
| 011                      | RXD signal of UART3                     |
| 100                      | Compare output signal of VC1            |
| 101                      | Compare output signal of VC2            |
| 110                      | LVD output signal                       |

# 14.4 Direct memory access (DMA)

Through the DMA trigger register GTIMx\_DMA, you can select GTIMx to trigger the DMA function when ARR overflow occurs, trigger start, and capture compare match. Using the DMA function, data can be written to the timer from other locations, or read from the timer and written to other locations. Can be applied to automatic data handling after data capture and changing the period or pulse width of the PWM output.

# 14.5 Debugging support

GTIM supports stop or continue counting in debug mode, which is set by the GTIMx bit field of the debug status timer control register SYSCTRL\_DEBUG.

Set SYSCTRL\_DEBUG.GTIMx to 1, then suspend the counter count of GTIMx in the debug state;

Set SYSCTRL\_DEBUG.GTIMx to 0, then the counter of GTIMx continues to count in the debug state.



# 14.6 Programming examples

#### 14.6.1 Timer mode programming example

The following is a programming example of timer mode. In this programming example, set the frequency of the system clock PCLK to 24MHz. After starting the timer for 10ms (9.99ms), an ARR overflow interrupt request will be generated and the counting will stop.

The configuration process is as follows:

- Step 1: Set the SYSCTRL\_APBEN1.GTIMx bit to 1, and turn on the configuration clock and working clock of GTIMx;
- Step 2: Set GTIMx\_CR0.MODE to 0x00 to make GTIMx work in timer mode;
- Step 3: Set GTIMx\_CR0.ONESHOT to 0x01 to make the counter work in single counting mode;
- Step 4: Set GTIMx\_CR0.PSC to 0xFF and the frequency division ratio to 256, then one cycle of the count clock TCLKD is about 10.67µs;
- Step 5: Set GTIMx\_ARR to 0x03A9 (937), then the ARR overflow period is about 10.008ms (ARR+1);
- Step 6: Set GTIMx\_CNT to 0x0000 for counting;
- Step 7: Set GTIMx\_IER.OV to 1 to allow ARR overflow interrupt;
- Step 8: Set GTIMx\_CR0.EN to 1 and start GTIMx;
- Step 9: ARR overflow interrupt is generated, enter the interrupt service routine, set GTIMx\_ICR.OV to 0 to clear the interrupt flag.

### 14.6.2 Counter mode programming examples

#### 14.6.2.1 Count external ETR signals

The steps to measure the number of rising edges of the signal input from the external GTIMx\_ETR pin are as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.GTIMx to 1, turn on the GPIO clock corresponding to the GTIMx\_ETR pin and the GTIMx configuration clock and working clock;
- Step 2: Configure the GPIO corresponding to the GTIMx\_ETR pin to the multiplexed input mode. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set GTIMx\_CR0.MODE to 0x01 to make GTIMx work in counter mode;
- Step 4: Set GTIMx\_CR0.TRS to 0x0, and select the counting source as the ETR input signal;
- Step 5: Configure GTIMX ETR.ETRFLT, choose whether to filter or filter bandwidth;
- Step 6: Set GTIMx\_CR0.POL to 0x0, and select the rising edge to count as valid;
- Step 7: Set GTIMx\_CR0.PSC to 0x01. In this example, the input ETR signal is not divided;
- Step 8: Set GTIMx\_ARR to 0xFFFF, and set the ARR overflow period to the maximum;
- Step 9: Set GTIMx\_CNT to 0x0000 for counting;
- Step 10: Set GTIMx\_CR0.EN to 0x1 to start GTIMx.



#### 14.6.2.2 Count internal ITR signal

In the following example, BTIM1 is used as the frequency divider of GTIM1 to divide the PCLK clock by 13. The operation steps are as follows:

- Step 1: Set the SYSCTRL\_APBEN1.GTIM1 bit to 1, and turn on the configuration clock and working clock of GTIM1;
- Step 2: Set GTIM1\_CR0.MODE to 0x01 to make GTIM1 work in counter mode;
- Step 3: Set GTIM1\_CR0.TRS to 0x1, and select the counting source as the internal ITR signal;
- Step 4: Set SYSCTRL\_TIMITR.GTIM1ITR to 0x00, select the ITR source of GTIM1 as the overflow signal of BTIM1;
- Step 5: Set GTIM1\_CR0.PSC to 0x01, do not divide the ITR signal, and complete the frequency division through BTIM1;
- Step 6: Set GTIM1\_ARR to 0xFFFF, and set the ARR overflow period to the maximum;
- Step 7: Set the initial value of GTIM1\_CNT to 0x0000 for counting;
- Step 8: Set GTIM1\_CR0.EN to 0x1 and start the timer;
- Step 9: Set the SYSCTRL\_APBEN2.BTIM bit to 1, and turn on the configuration clock and working clock of BTIM1;
- Step 10: Set BTIM1\_BCR.MODE to 0x00, select BTIM1 to work in timer mode, and use PCLK clock to count;
- Step 11: Set BTIM1\_BCR.PSC to 0x00, do not divide the frequency of the PCLK clock signal;
- Step 12: Set BTIM1\_BCR. ONESHOT to 0x00, BTIM1 is continuous counting mode;
- Step 13: Set the BTIM1\_ARR register to 0xC, so that BTIM1 will generate an overflow signal OV after counting (ARR+1) PCLK cycles, that is, 13 PCLK cycles. This OV signal is used as the input signal ITR of GTIM1, causing 1 of GTIM1 count;
- Step 14: Set the initial value of BTIM1\_CNT to 0x0000 for counting;
- Step 15: Set BTIM1\_BCR.EN to 0x1 to start BTIM1.

#### 14.6.3 Trigger start mode programming example

The counter is triggered to start counting by the signal input from the external GTIMx\_ETR pin. The operation steps are as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.GTIMx to 1, turn on the GPIO clock corresponding to the GTIMx\_ETR pin and the GTIMx configuration clock and working clock;
- Step 2: Configure the GPIO corresponding to the GTIMx\_ETR pin to the multiplexed input mode. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set GTIMx\_CR0.TRS to 0x0, and select the trigger signal as the ETR input signal;
- Step 4: Configure GTIMx\_ETR.ETRFLT, choose whether to filter or filter bandwidth;
- Step 5: Configure GTIMx\_CR0.POL, and set whether the trigger signal is valid on the rising or falling edge;
- Step 6: Set GTIMx\_CR0.PSC to 0x00. In this example, the PCLK clock is not divided;
- Step 7: Set GTIMx\_ARR to 0xFFFF, and set the ARR overflow period to the maximum;
- Step 8: Set the initial value of GTIMx\_CNT to 0x0000 for counting;
- Step 9: Set GTIMx\_ICR.TI to 0x0, clear interrupt flag;
- Step 10: If you need to enable the trigger interrupt request, set the register GTIMx\_IER.TI bit to 1;
- Step 11: Set GTIMx\_CR0.MODE to 0x02 to make GTIMx work in trigger mode. When a valid trigger signal is input, the counter will start to work.

#### Caution:

Set the polarity of the trigger signal first, and then set the timer mode, otherwise it will cause false triggering.



#### 14.6.4 Gated mode programming example

The signal input from the external GTIMx\_ETR pin is used as the gate control signal to control the count of the counter. The operation steps are as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.GTIMx to 1, turn on the GPIO clock corresponding to the GTIMx\_ETR pin and the GTIMx configuration clock and working clock;
- Step 2: Configure the GPIO corresponding to the GTIMx\_ETR pin to the multiplexed input mode. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set GTIMx\_CR0.MODE to 0x03 to make GTIMx work in gated mode;
- Step 4: Set GTIMx\_CR0.TRS to 0x0, and select the gate control signal as the ETR input signal;
- Step 5: Configure GTIMx\_ETR.ETRFLT, choose whether to filter or filter bandwidth;
- Step 6: Configure GTIMx\_CR0.POL, and set whether the gate control signal is active at high level or low level;
- Step 7: Set GTIMx\_CR0.PSC to 0x00. In this example, the PCLK clock is not divided;
- Step 8: Set GTIMx\_ARR to 0xFFFF, and set the ARR overflow period to the maximum;
- Step 9: Set the initial value of GTIMx\_CNT to 0x0000 for counting;
- Step 10: Set GTIMx\_CR0.EN to 0x01 to start the timer. When the gate control signal is valid, the counter will start to work.

#### 14.6.5 Input capture programming example

In timer mode, the steps to measure the width of a pulse are as follows:

- **Step 1:** Set the SYSCTRL\_APBEN1.GTIMx bit to 1, and turn on the configuration clock and working clock of GTIMx;
- Step 2: Set GTIMx\_CR0.MODE to 0x00 to make GTIMx work in timer mode;
- Step 3: Set GTIMx\_CR0.PSC and select the appropriate frequency division coefficient;
- Step 4: Set GTIMx\_ARR to an appropriate value according to the characteristics of the signal. If GTIMx\_ARR is set smaller, the counter clock frequency is faster, and the input pulse width is longer, GTIMx\_ARR may overflow. If an overflow occurs, the overflow flag needs to be cleared in time, and the pulse width time is calculated according to the number of times the overflow flag is generated;
- Step 5: Configure GTIMx\_CR1.CHyPOL and select the polarity of the signal sent to the internal circuit by channel CHy;
- Step 6: Configure GTIMx\_CR1.CHyFLT, configure channel CHy input filter;
- Step 7: Set GTIMx\_CMMR.CCyM to 0x01, select rising edge capture;
- Step 8: Set GTIMx\_IER.CCy to 0x01, allowing capture;
- Step 9: Set GTIMx\_CR0.EN to 0x1 and start the timer;
- Step 10: Wait for the capture interrupt to be generated, and read the current value in GTIMx\_CCRy. Then set the corresponding bit of GTIMx\_ICR.CCy to 0x0, clear the interrupt flag;
- Step 11: Set GTIMx\_CMMR.CCyM to 0x02 and select falling edge capture;
- Step 12: Wait for the next capture interrupt to be generated, and read the current value in GTIMx\_CCRy. The difference between the GTIMx\_CCRy values read twice in this way is the length of the input pulse width.



#### 14.6.6 Output compare programming example

In timer mode, the external output of low level through channel CH1 indicates that the timing time is up. The operation steps are as follows:

- Step 1: Set the SYSCTRL\_APBEN1.GTIMx bit to 1, and turn on the configuration clock and working clock of GTIMx;
- Step 2: Set GTIMx\_CR0.MODE to 0x00 to make GTIMx work in timer mode;
- Step 3: Set GTIMx\_CR0.PSC and select the appropriate frequency division coefficient;
- Step 4: Set GTIMx\_CMMR.CC1M to 0x0A, so that the CH1 channel of GTIMx is set to 0 when it is compared and matched;
- Step 5: Set GTIMx\_CNT to 0x0000, clear the counter;
- Step 6: Set GTIMx\_CCR1, set timing time;
- Step 7: Set GTIMx\_CR0.EN to 0x1 to start the timer. When the count value in GTIMx\_CNT is equal to the value of GTIMx\_CCR1, the output level on CH1 changes from high to low.

#### 14.6.7 PWM output programming example

In timer mode, the operation steps to output a PWM waveform are as follows:

- Step 1: Set the SYSCTRL\_APBEN1.GTIMx bit to 1, and turn on the configuration clock and working clock of GTIMx;
- Step 2: Set GTIMx CR0.MODE to 0x00 to make GTIMx work in timer mode;
- Step 3: Set GTIMx\_CR0.PSC and select the appropriate frequency division coefficient;
- Step 4: According to the period requirement of the output PWM waveform, set GTIMx\_ARR to an appropriate value, that is, GTIMx\_ARR can change the period of PWM;
- Step 5: According to the pulse width requirement of the output PWM waveform, set GTIMx\_CCRy to an appropriate value, that is, GTIMx\_CCRy can change the duty cycle of PWM;
- Step 6: Set GTIMx\_CMMR.CCyM to 0x0E, select PWM forward output, that is GTIMx\_CNT>=GTIMx\_CCRy output high level;
- Step 7: Set GTIMx\_IER.CCy to 0x01, enable compare interrupt;
- Step 8: Set GTIMx\_CR0.EN to 0x1 and start the timer;
- Step 9: Wait for the compare interrupt to be generated, modify the value of GTIMx\_CCRy as required to change the duty cycle of the PWM waveform, and then set the corresponding bit of GTIMx\_ICR.CCy to 0x0 to clear the interrupt flag.

#### 14.6.8 Encoder mode programming example

The steps to configure GTIMx to work in encoder mode 3 are as follows:

- Step 1: Set the SYSCTRL\_APBEN1.GTIMx bit to 1, and turn on the configuration clock and working clock of GTIMx;
- Step 2: Set the register GTIMx\_CR0.ENCMODE to 0x03, so that GTIMx works in encoding mode 3, and the counter counts on the edges of CH1 and CH2 at the same time;
- Step 3: Set the register GTIMx\_ARR and select the appropriate value;
- Step 4: Set the CH1POL and CH2POL bits in the GTIMx\_CR1 register to select the polarity of the CH1 and CH2 pin input signals sent to the internal circuit;
- Step 5: Set the CH1FLT and CH2FLT bits in the GTIMx\_CR1 register to select the appropriate filter configuration;
- **Step 6:** If you need to set the DIRCHANGE bit in the register GTIMx\_IER to enable, turn on the direction change interrupt;
- **Step 7:** Set GTIMx\_CR0.EN to 0x1 to start the timer.

# 14.7 List of registers

GTIM1 base address: GTIM1\_BASE = 0x4000 0700 GTIM2 base address: GTIM2\_BASE = 0x4000 1300

Table 14-10 List of GTIM registers

| Register name | Register address  | Register description              |
|---------------|-------------------|-----------------------------------|
| GTIMx_ARR     | GTIMx_BASE + 0x00 | Reload register                   |
| GTIMx_CNT     | GTIMx_BASE + 0x04 | Count register                    |
| GTIMx_CMMR    | GTIMx_BASE + 0x08 | Compare capture control register  |
| GTIMx_ETR     | GTIMx_BASE + 0x0C | External trigger control register |
| GTIMx_CR0     | GTIMx_BASE + 0x10 | Control register 0                |
| GTIMx_IER     | GTIMx_BASE + 0x14 | Interrupt enable register         |
| GTIMx_ISR     | GTIMx_BASE + 0x18 | Interrupt flag register           |
| GTIMx_ICR     | GTIMx_BASE + 0x1C | Interrupt flag clear register     |
| GTIMx_CCR1    | GTIMx_BASE + 0x20 | Compare capture register 1        |
| GTIMx_CCR2    | GTIMx_BASE + 0x24 | Compare capture register 2        |
| GTIMx_CCR3    | GTIMx_BASE + 0x28 | Compare capture register 3        |
| GTIMx_CCR4    | GTIMx_BASE + 0x2C | Compare capture register 4        |
| GTIMx_CR1     | GTIMx_BASE + 0x30 | Control register 1                |
| GTIMx_PSC     | GTIMx_BASE + 0x34 | Prescaler register                |
| GTIMx_DMA     | GTIMx_BASE + 0x40 | DMA trigger register              |

# 14.8 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

## 14.8.1 GTIMx\_CR0 control register 0

Address offset: 0x10 Reset value: 0x0000 0000

| Bit field | Name      | Permission | Function description                                                                                                                                                                                                                                                                                                                                           |
|-----------|-----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21     | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                   |
| 20:19     | ENCRELOAD | RW         | Encoding mode, count register external reload condition configuration 00: No function 01: CH3 rising edge reload count register CNT 10: CH3 falling edge reload count register CNT Caution: The reload operation makes the value of the CNT register equal to the value of the ARR register                                                                    |
| 18:17     | ENCRESET  | RW         | Encoding mode, count register external reset condition configuration 00: No function 01: CH3 rising edge reset count register CNT 10: CH3 falling edge reset count register CNT Caution 1: The reset operation makes the value of the CNT register equal to 0x0000; Caution 2: ENCRESET is valid when ENCRESET and ENCRELOAD are configured for the same edge. |
| 16:15     | ENCMODE   | RW         | Encoding counting mode enable configuration 00: The timer function is configured by the MODE bits 01: Encoding counting mode 1, CH1 signal change edge counting 10: Encoding counting mode 2, CH2 signal change edge counting 11: Encoding counting mode 3, CH1/CH2 signal change edge counting                                                                |
| 14:7      | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                   |
| 6         | TOGEN     | RW         | TOG pin output enable control 1: TOGP, TOGN output level is 0 1: TOGP, TOGN output signals with opposite levels                                                                                                                                                                                                                                                |
| 5         | ONESHOT   | RW         | Single/continuous counting mode control 0: Continuous counting mode 1: Single counting mode                                                                                                                                                                                                                                                                    |

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4         | POL  | RW         | ETR input signal polarity selection  0: ETR is positive (the rising edge of trigger mode is valid, and the gated mode is valid at high level)  1: ETR is reversed (the falling edge of trigger mode is valid, and the gated mode is valid at low level)                                                                                                                                                         |
| 3         | TRS  | RW         | Trigger source selection  0: ETR input signal  1: ITR, see section 14.3.6 Internal cascade ITR                                                                                                                                                                                                                                                                                                                  |
| 2:1       | MODE | RW         | Basic timing mode configuration 00: Timer mode, counting clock source is PCLK 01: Counter mode, counting clock source is TRS signal 10: Trigger start mode, the counting clock source is PCLK, and the TRS signal triggers the counter to start 11: Gated mode, counting clock source is PCLK, ETR input signal is used as gated Caution: In counter mode, the GTIMx_PSC register value must be greater than 0. |
| 0         | EN   | RW         | Timer running control 0: Timer stopped 1: Timer running                                                                                                                                                                                                                                                                                                                                                         |

## 14.8.2 GTIMx\_CR1 control register 1

Address offset: 0x30 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                          |
| 15        | CH4POL | RW         | CH4 channel input signal polarity configuration 0: The in-phase signal of the CH4 pin is sent to the internal circuit 1: The inverted signal of the CH4 pin is sent to the internal circuit                                                                                                                                                                                                                                           |
| 14:12     | CH4FLT | RW         | CH4 input signal filter configuration See CH1FLT for functional description                                                                                                                                                                                                                                                                                                                                                           |
| 11        | CH3POL | RW         | CH3 channel input signal polarity configuration 0: The in-phase signal of the CH3 pin is sent to the internal circuit 1: The inverted signal of the CH3 pin is sent to the internal circuit                                                                                                                                                                                                                                           |
| 10:8      | CH3FLT | RW         | CH3 input signal filter configuration See CH1FLT for functional description                                                                                                                                                                                                                                                                                                                                                           |
| 7         | CH2POL | RW         | CH2 channel input signal polarity configuration 0: The in-phase signal of the CH2 pin is sent to the internal circuit 1: The inverted signal of the CH2 pin is sent to the internal circuit                                                                                                                                                                                                                                           |
| 6:4       | CH2FLT | RW         | CH2 input signal filter configuration See CH1FLT for functional description                                                                                                                                                                                                                                                                                                                                                           |
| 3         | CH1POL | RW         | CH1 channel input signal polarity configuration 0: The in-phase signal of the CH1 pin is sent to the internal circuit 1: The inverted signal of the CH1 pin is sent to the internal circuit                                                                                                                                                                                                                                           |
| 2:0       | CH1FLT | RW         | CH1 input signal filtering configuration; sampling clock is PCLK or PCLK frequency division, the number of sampling points is N 000: no filtering 001: $F_{\text{sample}} = \text{PCLK}$ , N=2 010: $F_{\text{sample}} = \text{PCLK}$ , N=4 011: $F_{\text{sample}} = \text{PCLK}$ , N=6 100: $F_{\text{sample}} = \text{PCLK}/4$ , N=6 110: $F_{\text{sample}} = \text{PCLK}/8$ , N=6 110: $F_{\text{sample}} = \text{PCLK}/8$ , N=6 |

## 14.8.3 GTIMx\_PSC Prescaler register

Address offset: 0x34 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                         |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value                                                                                 |
| 15:0      | PSC  | RW         | Prescaler value When the count clock is PCLK: TCLKD = TCLK / ( PSC + 1 ) When the count clock is TRS: TCLKD = TCLK / PSC > 0 |

## 14.8.4 GTIMx\_ETR external trigger control register

Address offset: 0x0C Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|--------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7      | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6:4       | ETRFLT | RW         | ETR input signal filtering configuration; the sampling clock is PCLK or PCLK frequency division, and the number of sampling points is N 000: no filtering 001: $F_{\text{sample}} = \text{PCLK}$ , N=2 010: $F_{\text{sample}} = \text{PCLK}$ , N=4 011: $F_{\text{sample}} = \text{PCLK}$ , N=6 100: $F_{\text{sample}} = \text{PCLK}/4$ , N=4 101: $F_{\text{sample}} = \text{PCLK}/4$ , N=6 110: $F_{\text{sample}} = \text{PCLK}/8$ , N=4 111: $F_{\text{sample}} = \text{PCLK}/8$ , N=6 |
| 3:0       | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

## 14.8.5 GTIMx\_CMMR compare capture control register

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                               |
| 15:12     | CC4M | RW         | CH4 capture compare mode configuration See CC1M for functional description                                                                                                                                                                                                                                                                                                                                                 |
| 11:8      | CC3M | RW         | CH3 capture compare mode configuration See CC1M for functional description                                                                                                                                                                                                                                                                                                                                                 |
| 7:4       | CC2M | RW         | CH2 capture compare mode configuration See CC1M for functional description                                                                                                                                                                                                                                                                                                                                                 |
| 3:0       | CC1M | RW         | CH1 capture compare mode configuration 0000: No function 0001: Capture on rising edge 0010: Capture on falling edge 0011: Capture the rising and falling edges at the same time 1000: Force output low level 1001: Force output high level 1010: Set to 0 on compare match 1011: Set to 1 on compare match 1110: PWM positive output (CNT >= CCR output high level) 1111: PWM reverse output (CNT < CCR output high level) |

### 14.8.6 GTIMx\_ARR reload register

Address offset: 0x00 Reset value: 0x0000 FFFF

| Bit field | Name | Permission | Function description                                                                      |
|-----------|------|------------|-------------------------------------------------------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value                                              |
| 15:0      | ARR  | RW         | Timer reload value<br>Caution: In encoding counting mode, ARR should be set to<br>0xFFFF. |

### 14.8.7 GTIMx\_CNT count register

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | CNT  | RW         | Timer count value                            |



### 14.8.8 GTIMx\_CCR1 compare capture register 1

Address offset: 0x20 Reset value: 0x0000 FFFF

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | CCR  | RW         | CH1 channel compare/capture value            |

### 14.8.9 GTIMx\_CCR2 compare capture register 2

Address offset: 0x24 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | CCR  | RW         | CH2 channel compare/capture value            |

#### 14.8.10 GTIMx\_CCR3 compare capture register 3

Address offset: 0x28 Reset value: 0x0000 FFFF

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | CCR  | RW         | CH3 channel compare/capture value            |

#### 14.8.11 GTIMx\_CCR4 compare capture register 4

Address offset: 0x2C Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | CCR  | RW         | CH4 channel compare/capture value            |



# 14.8.12 GTIMx\_IER interrupt enable register

Address offset: 0x14 Reset value: 0x0000 0000

| Bit field | Name      | Permission | Function description                                                                                                                                |
|-----------|-----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10     | RFU       | -          | Reserved bits, please keep the default value                                                                                                        |
| 9         | DIRCHANGE | RW         | Encoder counting direction change interrupt control 0: Disabled 1: Enabled                                                                          |
| 8:7       | RFU       | -          | Reserved bits, please keep the default value                                                                                                        |
| 6         | CC4       | RW         | CH4 capture compare interrupt enable control 0: Disabled 1: Enabled                                                                                 |
| 5         | CC3       | RW         | CH3 capture compare interrupt enable control 0: Disabled 1: Enabled                                                                                 |
| 4         | CC2       | RW         | CH2 capture compare interrupt enable control 0: Disabled 1: Enabled                                                                                 |
| 3         | CC1       | RW         | CH1 capture compare interrupt enable control 0: Disabled 1: Enabled                                                                                 |
| 2         | UD        | RW         | Underflow interrupt enable control 0: Underflow interrupt disabled 1: Underflow interrupt enabled Caution: Only available in encoding counting mode |
| 1         | TI        | RW         | Trigger interrupt enable control 0: Trigger interrupt disabled 1: Trigger interrupt enabled                                                         |
| 0         | OV        | RW         | Counter ARR overflow interrupt enable control 0: ARR overflow interrupt disabled 1: ARR overflow interrupt enabled                                  |

# 14.8.13 GTIMx\_ISR interrupt flag register

Address offset: 0x18 Reset value: 0x0000 0000

| Bit field | Name      | Permission | Function description                                                                                                                                                           |
|-----------|-----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11     | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                   |
| 10        | DIR       | RO         | Encoder current counting direction flag 0: forward counting 1: reverse counting                                                                                                |
| 9         | DIRCHANGE | RO         | Encoder counting direction change interrupt flag 0: The counting direction has not changed 1: The counting direction has been changed                                          |
| 8:7       | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                   |
| 6         | CC4       | RO         | CH4 compare capture interrupt flag 0: No compare capture event occurred 1: The compare capture event has occurred                                                              |
| 5         | CC3       | RO         | CH3 compare capture interrupt flag 0: No compare capture event occurred 1: The compare capture event has occurred                                                              |
| 4         | CC2       | RO         | CH2 compare capture interrupt flag 0: No compare capture event occurred 1: The compare capture event has occurred                                                              |
| 3         | CC1       | RO         | CH1 compare capture interrupt flag 0: No compare capture event occurred 1: The compare capture event has occurred                                                              |
| 2         | UD        | RO         | Counter underflow flag 0: The counter has not underflowed 1: The counter has underflowed Caution: Only available in encoding counting mode                                     |
| 1         | TI        | RO         | Trigger flag 0: No trigger event occurred 1: The trigger event has occurred                                                                                                    |
| 0         | OV        | RO         | Counter ARR overflow flag 0: The counter has not ARR overflowed 1: The counter has ARR overflowed Caution: This flag is generated when the counter value changes from ARR to 0 |

# 14.8.14 GTIMx\_ICR interrupt flag clear register

Address offset: 0x1C Reset value: 0x0000 03FF

| Bit field | Name      | Permission | Function description                                                                                                                 |
|-----------|-----------|------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:10     | RFU       | -          | Reserved bits, please keep the default value                                                                                         |
| 9         | DIRCHANGE | R1W0       | Encoder counting direction change interrupt control W0: The encoder counting direction change interrupt flag cleared W1: No function |
| 8:7       | RFU       | -          | Reserved bits, please keep the default value                                                                                         |
| 6         | CC4       | R1W0       | CH4 compare capture interrupt flag cleared<br>W0: Compare capture interrupt flag cleared<br>W1: No function                          |
| 5         | CC3       | R1W0       | CH3 compare capture interrupt flag cleared<br>W0: Compare capture interrupt flag cleared<br>W1: No function                          |
| 4         | CC2       | R1W0       | CH2 Compare capture interrupt flag cleared<br>W0: Compare capture interrupt flag cleared<br>W1: No function                          |
| 3         | CC1       | R1W0       | CH1 compare capture interrupt flag cleared<br>W0: Compare capture interrupt flag cleared<br>W1: No function                          |
| 2         | UD        | R1W0       | Counter underflow flag cleared W0: Counter underflow flag cleared W1: No function Caution: Only available in encoder counting mode   |
| 1         | TI        | R1W0       | Trigger flag cleared<br>W0: Trigger flag cleared<br>W1: No function                                                                  |
| 0         | OV        | R1W0       | Counter ARR overflow flag cleared<br>W0: Counter ARR overflow flag cleared<br>W1: No function                                        |

## 14.8.15 GTIMx\_DMA DMA trigger register

Address offset: 0x40 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                    |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                            |
| 5         | CC4  | RW         | CH4 capture compare interrupt trigger DMA enable control 0: Disabled 1: Enabled                                                                                         |
| 4         | CC3  | RW         | CH3 capture compare interrupt trigger DMA enable control 0: Disabled 1: Enabled                                                                                         |
| 3         | CC2  | RW         | CH2 capture compare interrupt trigger DMA enable control 0: Disabled 1: Enabled                                                                                         |
| 2         | CC1  | RW         | CH1 capture compare interrupt trigger DMA enable control 0: Disabled 1: Enabled                                                                                         |
| 1         | TRS  | RW         | Synchronous trigger DMA enable control when the counter is triggered to start  0: No function  1: DMA is triggered synchronously when the counter is triggered to start |
| 0         | OV   | RW         | Counter ARR overflow triggers DMA enable control 0: No function 1: Counter ARR overflow triggers DMA                                                                    |

## 15 Advanced-control timer (ATIM)

#### 15.1 Overview

The Advanced-control Timer (ATIM) consists of a 16-bit auto-reload counter and 7 compare units, driven by a programmable prescaler. ATIM supports 6 independent capture/compare channels, which can realize 6 independent PWM outputs or 3 pairs of complementary PWM outputs or capture 6 inputs. Can be used for basic timing/counting, measuring pulse width and period of input signals, generating output waveforms (PWM, single pulse, complementary PWM with dead time inserted, etc.).

#### 15.2 Main features

- 16-bit up, down, up/down autoload counter
- 6 independent channels for input capture and output compare
- PWM generation (Edge- and Center-aligned modes)
- Complementary PWM outputs with programmable dead-time
- Brake function
- One-pulse mode output
- Quadrature encoding counting function
- Supports for interrupt and events
  - Counter overflow/underflow
  - Capture and compare events
  - Capture data loss
  - Break event
  - Update event
  - Trigger event

### 15.3 Functional description

#### 15.3.1 Functional block diagram

The functional block diagram of ATIM is shown in the following figure:

CR.PRS CR.CT Repeat count register Overloading register ARR PCLKD **PCLK** Pre-divider Repeat counter CR.OVE ETFP Phase TCLK Overflow ETR ⊠-Filtering selection interruption ITR 16-bit counter UND Underflow TS IAFP Trig interruption Phase Filtering selection Phase IBFP CR.UNDE Filtering selection MSCR.TS CH1A ⊠-Phase Capture/Compare Filtering Output Control Register CCR1A XOR ►⊠ CH1A COMP DTR MSCR.IA1S CH1B ⊠ Output ►⊠ CH1B Capture/Compare Register CCR1B Phase Control Filtering TS selection COMP MSCR.IB1S Phase Capture/Compare Filtering CH2A ⊠selection Register CCR2A Output **►**⊠ CH2A Control A DTR COMP Output ►⊠ CH2B Phase Capture/Compare CH2B ⊠-Filtering Control selection Register CCR2B COMP Capture/Compare Filtering СНЗА ⊠selection Register CCR3A Output **►**⊠CH3A Control DTR COMP Output **►**⊠СН3В Phase Capture/Compare Control СНЗВ ⊠-Filtering selection Register CR3B COMP Capture/Compare Register CCR4 Phase Filtering selection

Figure 15-1 ATIM functional block diagram

Through the combination of 16-bit counter and 7 comparison unit, the functions of input capture and output comparison can be realized, which can be used to measure pulse width and period of input signal, and can output PWM waveform.



#### 15.3.1.1 Clock sources selection

The counting clock source of the counting unit can be selected from the internal system clock PCLK or the ETR input signal, which is specifically selected by the CT bit field of the control register ATIM\_CR.

When ATIM\_CR.CT is set to 0, the counting clock source is the internal system clock PCLK, and the internal clock PCLK can be divided by ATIM CR.PRS.

When ATIM\_CR.CT is set to 1, the counting clock source is the ETR input signal (for the specific source of the ETR signal, please refer to section *15.3.9 On-chip peripheral interconnect ETR*). The filter can be controlled by ATIM FLTR.FLTET, and the ETR input phase can be selected by ATIM FLTR.ETP.

#### 15.3.1.2 Update Event (UEV)

The update source of update event UEV (Event) is set through the URS bit field of the control register ATIM\_CR, as shown in the following table:

| ATIM_CR.URS | Update source                                                                                                                        |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 0           | The counter overflow and underflow (and the number of repetition counts ATIM_RCR is 0); UG is set by software; Reset from slave mode |
| 1           | The counter overflow and underflow (and the number of repetition counts ATIM_RCR is 0)                                               |

Table 15-1 Update source settings

When an update event occurs (the internal UEV signal is held for one PCLK cycle), the ATIM performs the following actions:

- 1. The counter is reset:
  - Edge-aligned mode: initialize to 0 when counting up, reload ATIM\_ARR when counting down; Center Aligned Mode: change the counting direction.
- 2. If the cache register function is used, ATIM\_ARR, ATIM\_CHxCCRy will be updated to its cache register.
- 3. The prescaler counter is cleared, but does not affect the prescaler value in ATIM\_CR.PRS.

  When an update event UEV occurs, the event update interrupt flag ATIM\_ISR.UIF will be set by hardware. If the interrupt is enabled (set ATIM\_CR.UIE to 1), an update interrupt request will be generated. Set ATIM\_ICR.UIE to 0 to clear the flag bit.

#### Caution:

If the repeatition counter is used (ATIM\_RCR.RCR is not 0), the update event UEV will only be generated when the count reaches the repeat count (ATIM\_RCR.RCR reaches 0).



#### 15.3.1.3 Counting modes

The counter can be set to upcounting (edge-aligned mode), downcounting (edge-aligned mode), or up/down counting bidirectionally (center-aligned mode).

#### **Upcounting mode**

When the DIR bit of the control register ATIM\_CR is set to 0 in edge-aligned mode, the counter works in the upcounting mode.

Setting ATIM\_CR.EN to 1 enables ATIM, and the counter CNT starts to count up. When the count value reaches the reload value ARR, the overflow signal OV is generated (the overflow signal OV remains for one PCLK cycle, and then automatically cleared). At the next PCLK, the counter is initialized to 0, and the counter overflow interrupt flag bit ATIM\_ISR.OVF is set by hardware. If the interrupt is enabled (set ATIM\_CR.OVE to 1), an interrupt request will be generated, set ATIM\_ICR.OVF to 0 to clear this flag bit.

If the repeatition counter is used, the update event (UEV) is generated when upcounting reaches the programmed number of repeat times(ATIM\_RCR.RCR), else the update event is generated at each counter overflow

The following figures show some examples of the counter behavior for different clock frequencies, where  $ATIM\_ARR = 0x36$ .



Figure 15-2 Upcounting, internal clock divided by 1







271 / 572

Figure 15-4 Upcounting, internal clock divided by 4



Figure 15-5 Upcounting, internal clock divided by N



Figure 15-6 Upcounting, update event when reload buffer is disabled (ATIM\_CR.BUFPEN=0x0)







Figure 15-7 Upcounting, update event when reload buffer is enabled (ATIM\_CR.BUFPEN=0x1)

#### Downcounting mode

When the DIR bit of the control register ATIM\_CR is set to 1 in edge-aligned mode, the counter works in the downcounting mode.

Set ATIM\_CR.EN to 1 to start ATIM, the hardware automatically loads ARR to the counter CNT, and the counter starts to count down. When the count value reaches 0, the overflow signal UND is generated (the overflow signal UND remains for one PCLK cycle, and then automatically cleared). One PCLK after overflow, the counter is reloaded with the value of ARR, the counter underflow interrupt flag ATIM\_ISR.UNDF is set by hardware, if interrupt is enabled (set ATIM\_CR.UNDE to 1), an interrupt request will be generated, set ATIM\_ICR.UNDF to 0 to clear this flag bit.

If the repeatition counter is used, the update event (UEV) is generated when upcounting reaches the programmed number of repeat times(ATIM\_RCR.RCR), else the update event is generated at each counter downflow.

The following figures show some examples of the counter behavior for different clock frequencies, where ATIM\_ARR = 0x36.



Figure 15-8 Downcounting, internal clock divided by 1

Figure 15-9 Downcounting, internal clock divided by 2



Figure 15-10 Downcounting, internal clock divided by 4



Figure 15-11 Downcounting, internal clock divided by N







Figure 15-12 Downcounting, update event when reload buffer enabled is not used

#### Center-aligned mode (up/down counting)

In center-aligned mode, the counter counts from 0 to the reload value ARR, generates a counter overflow event, then counts down to 0 and generates a counter underflow event. Then it restarts counting up from 0.

In center-aligned mode, the DIR direction bit in the ATIM\_CR register cannot be written but can be read. It is updated by hardware and gives the current direction of the counter. The DIR bit is automatically cleared to 0 when switching from other modes to center-aligned mode

If the repeatition counter is used, the update event (UEV) is generated when up/down counting reaches the programmed number of repeat times(ATIM\_RCR.RCR), else the update event is generated at each counter overflow/downflow.

The following figures show some examples of the counter behavior for different clock frequencies:



Figure 15-13 Center-aligned mode, internal clock divided by 1, ARR=0x06

Figure 15-14 Center-aligned mode, internal clock divided by 2



Figure 15-15 Center-aligned mode, internal clock divided by 4, ARR=0x36



Figure 15-16 Center-aligned mode, internal clock divided by N



PCLK
EN
TCLK
CNT
0x31
0x32
0x33
0x34
0x35
0x36
0x35
0x34
0x33
0x32
0x31
0x30
0x2F

OV
UEV
UIF
ARR
0xFF
0x36
Write 0x36 to the ARR register

Figure 15-17 Center-aligned mode, update event when reload buffer is disabled (ATIM\_CR.BUFPEN=0x0)





#### 15.3.1.4 Reload register

The auto-reload register ATIM\_ARR has a buffer function, which is started or closed by the BUFPEN bit field of the control register ATIM\_CR.

When the counter is stopped or the buffer function is disabled, updating the reload register ARR will immediately update the buffer register. When the timer is running and the buffer function is valid, updating the reload register ARR will not update the buffer register immediately, and will only update the value of the reload register ARR to the buffer register when there is an update event UEV.



#### 15.3.1.5 Repetition counter

Starting ATIM will auto-load the RCR of the repeat count register ATIM\_RCR to the repetition counter. When the main counter overflows, it will automatically decrease by one according to the UD and OV enable bits of the ATIM\_RCR register, as shown in the following table:

Table 15-2 Repetition counter count configuration

| Main counter overflow type | Working<br>mode      | ATIM_CR.DIR     | ATIM_RCR.UD | ATIM_RCR.OV | Repetition counter action |
|----------------------------|----------------------|-----------------|-------------|-------------|---------------------------|
|                            | Edge-aligned<br>mode | 0, upcounting   | -           | 0           | Minus one                 |
| Overflow                   |                      |                 | -           | 1           | No count                  |
| Overnow                    | Center-aligned mode  |                 | -           | 0           | Minus one                 |
|                            |                      | _               | -           | 1           | No count                  |
|                            | Edge-aligned<br>mode | 1, downcounting | 0           | -           | Minus one                 |
| Underflow                  |                      |                 | 1           | -           | No count                  |
| Underflow                  | Center-aligned       |                 | 0           | -           | Minus one                 |
|                            | mode                 | -               |             | -           | No count                  |

When using the repeat counter function (the RCR of ATIM\_RCR is not set to 0), the overflow of the main counter will generate the update event (UEV) only when the repeat counter is decremented to 0.

When UG is updated by software or reset from slave mode, the update event (UEV) will be generated immediately, regardless of the current value of the repetitiont counter, and the content of the RCR in the ATIM\_RCR register will be loaded into the repetition counter immediately.

The following figure is example of different repetition count values, and the update event (UEV) is generated in different counting modes:

Central alignment model

CNT

Upward counting

Downward counting

RCR.RCR=0

UEV

RCR.RCR=1

UEV

RCR.RCR=2

UEV

RCR.RCR=3

and resync

UEV

LUEV

LU

Figure 15-19 Repetition counting example



#### 15.3.1.6 Compare/capture channels

ATIM has 3 independent compare/capture channels CH1, CH2, CH3, each channel has A and B compare/capture registers and their buffer registers, as well as input signal processing units (digital filtering and phase detection), comparison units, and matching output unit.

Therefore, ATIM can realize 6-channel input capture, or 6-channel independent PWM output, or 3 pairs of complementary PWM output. Channel CH4 of ATIM is an internal channel of the chip, with no external pins, only one compare/capture register (ATIM\_CH4CCR), which can only be used for comparison and cannot be used for capture.

The corresponding pins of the compare/capture channel supported by ATIM are shown in the following table, and the function multiplexing needs to be configured in the application.

Table 15-3 ATIM compare/capture channel pins

| ATIM      | Pin                 | AFR  |
|-----------|---------------------|------|
| ATIM_CH1A | PA05/PA08/PB02      | 0x07 |
| ATIM_CH1B | PA07                | 0x07 |
| ATIM_CH2A | PA04/PA09/PB10      | 0x07 |
| ATIM_CH2B | PB00/PB14           | 0x07 |
| ATIM_CH3A | PA03/PA10/PB07/PB11 | 0x07 |
| ATIM_CH3B | PB01/PB15           | 0x07 |

#### 15.3.2 Input capture mode

#### 15.3.2.1 Input capture

Input capture is supported in both edge-aligned and center-aligned modes. Set the CSy bit field of the channel x control register ATIM\_CHxCR to 1, so that the channel CHxy (x=1~3, y=A, B) works in the input capture mode, and the input capture can be triggered by software or hardware.

Software trigger: When ATIM\_CHxCR.CCGy is set to 1, the software triggers a capture immediately, the value of main count register ATIM\_CNT is latched into the compare/capture register ATIM\_CHxCCRy of the corresponding channel, and a capture is completed. After the capture is completed, the CCGy bit is automatically cleared by hardware.

Hardware trigger: When the valid edge on the channel CHxy is detected, the value of main count register ATIM\_CNT is latched into the compare capture register ATIM\_CHxCCRy of the corresponding channel to complete a capture. The valid edge that triggers the capture is selected by the BKSy bit field of the ATIM\_CHxCR register, as shown in the following table:

| Advanced Timer | ChannelCHxy     | BKSy bit field value | Capture trigger condition                |
|----------------|-----------------|----------------------|------------------------------------------|
|                | BKSy<br>(y=A,B) | 00                   | Prohibit                                 |
| ATIM_CHxCR     |                 | 01                   | Capture on rising edge                   |
| (x=1,2,3)      |                 | 10                   | Capture on falling edge                  |
|                |                 | 11                   | Capture on both rising and falling edges |

Table 15-4 Input capture mode configuration

When a capture occurs, the capture interrupt flag bit ATIM\_ISR.CxyF of the corresponding channel is set by hardware. If the interrupt is enabled (set ATIM\_CHxCR.CIEy to 1), an interrupt request will be generated; if DMA is enabled (set ATIM\_CHxCR.CDEy to 1)), a DMA request will be generated. If the ATIM\_ISR.CxyF flag is already high when a capture event occurs, the recapture flag ATIM\_ISR.CxyE will be set by hardware. Set ATIM\_ICR.CxyF to 0 to clear the ATIM\_ISR. CxyF flag, set ATIM\_ICR.CxyE to 0 to clear the ATIM\_ISR.CxyE flag.

#### Caution:

Even if ATIM is not started and ATIM\_CNT does not start counting, when the valid edge of channel CHxy is detected, the capture will still be triggered and the capture action will be executed.

#### 15.3.2.2 PWM input mode

PWM input mode is an application of input capture mode. Set the BKSy bit field of the channel x control register ATIM\_CHxCR to 0x03, so that the timer captures both rising and falling edges of PWM input signal. After three captures, the pulse width and period of the PWM signal can be calculated.

The schematic diagram of PWM signal measurement of CH3B channel is shown in the following figure:



Figure 15-20 Schematic diagram of PWM measurement

#### 15.3.2.3 Input capture trigger source

The input capture trigger source of ATIM can choose the external CHxy pin input signal, or the internal trigger TS signal.

The input capture of channels CH2A, CH2B, CH3A, and CH3B can only select the corresponding external GPIO pin input. The channel filter setting can be performed through the OCMxyFLTxy bit field of the filter register ATIM\_FLTR, and the phase setting can be performed through the ATIM\_CHxCR.BKSy bit field.

CH1 of ATIM is an input channel with advanced functions. Input terminals CH1A and CH1B can be used as trigger capture and trigger start of main counter.

The input capture of CH1A is determined by the IA1S bit field of the master-slave mode control register ATIM\_MSCR, and the input of CH1A or the exclusive OR input of CH1A, CH2A and CH3A can be selected.

Select CHIA input when ATIM\_MSCR.IA1S is set to 0, the channel filter can be set by ATIM\_FLTR.OCM1AFLT1A, and the phase can be set by ATIM\_CH1CR.BKSA; when ATIM\_MSCR.IA1S is set to 1, the XOR input of CH1A, CH2A, and CH3A can be selected. This feature is used for Connect the hall sensor.

The input capture of CH1B is determined by the IB1S bit field of the master-slave mode control register ATIM\_MSCR, and the CH1B input or the internal trigger TS signal can be selected.

When ATIM\_MSCR.IB1S is set to 0, the CH1B input is selected, the channel filter can be set by ATIM\_FLTR. OCM1BFLT1B, and the phase can be set by ATIM\_CH1CR.BKSB; when ATIM\_MSCR.IB1S is set to 1, the internal trigger TS signal is selected, and the TS signal is configured by ATIM\_MSCR.TS source, as shown in the following table:

Table 15-5 TS signal sources

| ATIM_MSCR.TS | TS signal                                            |
|--------------|------------------------------------------------------|
| 000          | ETR filtered and phase-selected signal ETFP          |
| 001          | Internal interconnect signal ITR                     |
| 101          | Edge signal of port CH1A                             |
| 110          | Filtered and phase-selected signal IAFP at port CH1A |
| 111          | Filtered and phase-selected signal IBFP at port CH1B |

#### 15.3.3 Output compare function

#### 15.3.3.1 Output compare

Set the CSy bit field of the channel x control register ATIM\_CHxCR to 0, so that the channel CHxy works in the output compare mode. In the output compare mode, compare the value of the count register ATIM\_CNT with the value of the compare/capture register ATIM\_CHxCCRy of the corresponding channel CHxy. When the two match, the compare/capture channel CHxy outputs a settable level state.

The output state of the compare channel is set by the OCMxyFLTxy bit field of the ATIM\_FLTR register, as shown in the following table:

| ATIM_FLTR.OCMxyFLTxy | Compare mode configuration                              |
|----------------------|---------------------------------------------------------|
| 000                  | Force CHxy to output low level                          |
| 001                  | Force CHxy to output high level                         |
| 010                  | CHxy is set to 0 on compare match                       |
| 011                  | CHxy is set to 1 on compare match                       |
| 100                  | CHxy flips output on compare match                      |
| 101                  | Output high level for one count period on compare match |
| 110                  | PWM mode 1                                              |
| 111                  | PWM mode 2                                              |

Table 15-6 Output compare mode configuration

The output polarity control bit CCPxy in the ATIM\_FLTR register sets the output polarity of CHxy.

When a compare match occurs, the hardware sets the channel compare/match interrupt flag ATIM\_ISR.CxyF, and at the same time:

- If the interrupt is enabled, that is, ATIM\_CHxCR.CIEy is 1, an interrupt request will be generated;
- If DMA is allowed to be triggered, that is, ATIM\_MSCR.CCDS is 0, the compare match triggers a DMA request;
- If the DMA is allowed to be enabled, that is, ATIM\_CHxCR.CDEy is 1, the compare/match enables the DMA;
- If ADC triggering is enabled, that is, ATIM\_TRIG.ADTE is 1, and ATIM\_TRIG.CMxyE is 1, a compare match will trigger an ADC conversion request.

The compare/capture register ATIM\_CHxCCRy has a cache function, and whether to use the buffer function is selected by the BUFEy bit of the ATIM\_CHxCR register.

When ATIM\_CHxCR.BUFEy is 0, the compare cache function of channel CHxy is disabled, and the ATIM\_CHxCCRy register can be updated by software at any time, and the updated value takes effect immediately and affects the output waveform; when ATIM\_CHxCR.BUFEy is 1, the compare cache of channel CHxy is enabled function, updating the ATIM\_CHxCCRy register will not update the cache register immediately, only when the update event UEV occurs, the value of the ATIM\_CHxCCRy register will be updated to the cache register.

The example of the compare/capture register cache function is shown in the following figure:





Figure 15-21 Compare/capture register cache function

#### 15.3.3.2 Forced output

In forced output mode, the output state of the compare channel CHxy is directly forced to be 0 or 1 by the software, without depending on the comparison result. The OCMxyFLTxy bit field in the ATIM\_FLTR register is set to 0x0, and the corresponding CHxy channel is forced to output low level; the OCMxyFLTxy bit field in the ATIM\_FLTR register is set to 0x1, and the corresponding CHxy channel is forced to output high level.

In forced output mode, the ATIM\_CHxCCRy register and the counter ATIM\_CNT are continuously compared, and the comparison result will affect the corresponding flag bit, and also generate corresponding interrupts and DMA requests.

#### 15.3.3.3 Single pulse mode

The single pulse mode is a kind of PWM output mode. After the counter responds to the trigger, one pulse output is generated after a delay. The delay time and pulse width can be controlled by a program.

The single pulse mode needs to set the ATIM slave mode. For the slave mode and its trigger conditions, please refer to section *15.3.7 Slave mode*.

The OCMxyFLTxy bit field of the output control/input filter register ATIM\_FLTR should be set to output compare mode or PWM output mode. At the same time, set the ONESHOT bit field of the control register ATIM\_CR to 0x1, and select the single transmitting mode, the counter will generate the next update Stop counting on event UEV.

Before starting the single pulse mode, pay attention to the current value of the counter CNT, the reload value ARR, and the compare value CHxCCRy, which should meet the following conditions:

- Upcounting method: CNT < CHxCCRy <= ARR</li>
- Downcounting method: CNT > CHxCCRy

Counter A

ARR
CHxCCRy

Figure 15-22 Example of single pulse output (upcounting method)

After starting the timer with the slave mode trigger, the timer starts counting when it detects the valid edge of the trigger signal, and after a delay of  $t_{DELAY}$ , a positive pulse with a width of  $t_{PULSE}$  is generated on the compare output port. Among them,  $t_{DELAY}$  is determined by the difference between the initial value of the counting register ATIM\_CNT and the compare/capture register ATIM\_CHxCCRy, and  $t_{PULSE}$  is determined by the reload register ATIM\_ARR and the compare/capture register ATIM\_CHxCCRy.

#### 15.3.3.4 Independent PWM output

The PWM (pulse width modulation) output mode of ATIM can generate a PWM waveform with programmable frequency and duty cycle. The frequency is determined by the reload register ATIM\_ARR, and the duty cycle is determined by compare/capture register ATIM\_CHxCCRy.

The PWM output mode needs to set the control register ATIM\_CR, filter register ATIM\_FLTR and dead-time register ATIM\_DTR, as shown in the following table:

PWM mode Bit field value Registers Bit field Description ATIM\_CR COMP Independent PWM output mode **PWM** ATIM\_FLTR **OCMxyFLTxy** 110 PWM mode 1 mode 1 MOE 1 Enable PWM output ATIM\_DTR COMP 0 Independent PWM output mode ATIM\_CR PWM PWM mode 2 ATIM\_FLTR OCMxyFLTxy 111 mode 2 MOE 1 Enable PWM output ATIM\_DTR

Table 15-7 PWM output mode

In PWM mode, channel A of the compare channel CHx can be configured as single-point compare or double-point compare through the PWM2S bit field of the control register ATIM\_CR. In the single-point compare mode, use the compare/capture register ATIM\_CHxCCRA to control the compare output; in the double-point compare mode, use the compare/capture registers ATIM\_CHxCCRA and ATIM\_CHxCCRB to control the compare output. The channel B of the compare channel can only use single-point compare, and the compare output is controlled by the compare/capture register ATIM\_CHxCCRB.

The output states of PWM modes 1 and 2 in different compare modes are shown in the following table:

Compare Counting Operating mode PWM mode 1 PWM mode 2 mode direction Upcounting CNT < CHxCCRy, output high CNT < CHxCCRy, output low Single-Edge-aligned mode, point center-aligned mode Downcounting CNT > CHxCCRy, output low CNT > CHxCCRy, output high CHxCCRA <= CNT < CHxCCRB, CHxCCRA < CNT <= CHxCCRB, Upcounting output low output high Edge-aligned mode CHxCCRA < CNT <= CHxCCRB, CHxCCRA <= CNT < CHxCCRB, Double-Downcounting output high output low point Upcounting CNT < CHxCCRA, output high CNT < CHxCCRA, output low Center Aligned Mode CNT > CHxCCRB, output low CNT > CHxCCRB, output high Downcounting

Table 15-8 PWM mode 1, 2 output state in different compare modes

The following are examples of independent PWM outputs of ATIM in different modes:





Figure 15-23 PWM mode 2, edge-aligned, upcounting, single-point comparison

- Step 1: Set the SYSCTRL\_APBEN2.ATIM bit to 1 and open the ATIM module;
- Step 2: Set the register ATIM\_CR.MODE to 0x2, the timer works in edge-aligned mode;
- Step 3: Set the register ATIM\_CR.COMP to 0x0, set as independent PWM output;
- Step 4: Set the register ATIM\_CR.DIR to 0x0, and the edge-aligned counting direction is upcounting;
- Step 5: Set ATIM\_ARR according to the period of PWM;
- Step 6: Set the initial value of the counter ATIM\_CNT (the initial value must be less than the value of ATIM\_ARR);
- Step 7: Set compare registers ATIM\_CHxCCRA, ATIM\_CHxCCRB according to the PWM pulse width;
- Step 8: Set ATIM\_FLTR.OCMxBFLTxB and ATIM\_FLTR.OCMxAFLTxA to 0x7, select compare output mode as PWM mode 2;
- Step 9: Set the relevant bits of the ATIM\_ICR register and clear the relevant interrupt flag;
- Step 10: If necessary, set the relevant interrupt enable;
- Step 11: Set ATIM\_FLTR.CCPxA and ATIM\_FLTR.CCPxB to 0, select no inverting output;
- Step 12: Set ATIM\_DTR.MOE to 0x01 to enable PWM output;
- **Step 13:** Set the register ATIM\_CR.EN to 0x01 to start the timer.



Figure 15-24 PWM mode 2, edge-aligned, downcounting, single-point comparison

- Step 1: Set the SYSCTRL\_APBEN2.ATIM bit to 1 and open the ATIM module;
- Step 2: Set the register ATIM\_CR.MODE to 0x2, the timer works in edge-aligned mode
- Step 3: Set the register ATIM\_CR.COMP to 0x0, set as independent PWM output;
- Step 4: Set the register ATIM\_CR.DIR to 0x1, and the edge-aligned counting direction is downcounting;
- Step 5: Set ATIM\_ARR according to the period of PWM;
- Step 6: Set the initial value of the counter ATIM\_CNT (the initial value must be less than the value of ATIM\_ARR);
- Step 7: Set compare registers ATIM\_CHxCCRA, ATIM\_CHxCCRB according to the PWM pulse width;
- Step 8: Set ATIM\_FLTR.OCMxBFLTxB and ATIM\_FLTR.OCMxAFLTxA to 0x7, so that the compare output mode is PWM mode 2;
- Step 9: Set the relevant bits of the ATIM\_ICR register and clear the relevant interrupt flag;
- Step 10: If necessary, set the relevant interrupt enable;
- Step 11: Set ATIM\_FLTR.CCPxA and ATIM\_FLTR.CCPxB to 0, no inverting output is required;
- Step 12: Set ATIM\_DTR.MOE to 0x01 to enable PWM output;
- Step 13: Set the register ATIM\_CR.EN to 0x01 to enable the timer.



Figure 15-25 PWM mode 2, center Aligned, single-point comparison

- Step 1: Set the SYSCTRL\_APBEN2.ATIM bit to 1 and open the ATIM module;
- Step 2: Set the register ATIM\_CR.MODE to 0x3, the timer works in center-aligned mode;
- Step 3: Set register ATIM\_CR.COMP to 0x0, set as independent PWM output;
- Step 4: Set ATIM\_ARR according to the period of the PWM;
- Step 5: Set the initial value of the counter ATIM\_CNT (the initial value must be less than the value of ATIM\_ARR);
- Step 6: Set compare registers ATIM\_CHxCCRA, ATIM\_CHxCCRB according to PWM pulse width;
- Step 7: Set ATIM\_FLTR.OCMxBFLTxB and ATIM\_FLTR.OCMxAFLTxA to 0x7 to make the compare output mode PWM edge-aligned;
- Step 8: Set the relevant bits of the ATIM\_ICR register and clear the relevant interrupt flags;
- Step 9: Set related interrupt enable if needed;
- Step 10: Set ATIM\_FLTR.CCPxA and ATIM\_FLTR.CCPxB to 0, no inverting output required;
- Step 11: Set ATIM\_DTR.MOE to 0x01 to enable PWM output;
- Step 12: Set the register ATIM\_CR.EN to 0x01 to enable the timer.



Figure 15-26 PWM mode 2, edge-aligned, two-point comparison

- Step 1: Set the system control register SYSCTRL\_APBEN2.ATIM bit to 1 and open the ATIM module;
- Step 2: Set the register ATIM\_CR.MODE to 0x2, the timer works in edge-aligned mode;
- Step 3: Set register ATIM CR.COMP to 0x0, set as independent PWM output;
- Step 4: Set the register ATIM\_CR.DIR to 0x0, and the edge-aligned counting direction is upcounting;
- Step 5: Set ATIM\_ARR according to the period of the PWM;
- Step 6: Set the initial value of the counter ATIM\_CNT (the initial value must be less than the value of ATIM\_ARR);
- Step 7: Set the compare registers ATIM\_CHxCCRA, ATIM\_CHxCCRB according to the PWM pulse width;
- Step 8: Set ATIM\_FLTR.OCMxBFLTxB and ATIM\_FLTR.OCMxAFLTxA to 0x7 to make the compare output mode PWM mode 2;
- Step 9: Set the relevant bits of the ATIM\_ICR register and clear the relevant interrupt flags;
- **Step 10:** Set related interrupt enable if needed;
- Step 11: Set ATIM\_FLTR.CCPxA and ATIM\_FLTR.CCPxB to 0, no inverting output required;
- Step 12: Set ATIM\_DTR.MOE to 0x01 to enable PWM output;
- Step 13: Set the register ATIM\_CR.EN to 0x01 to enable the timer.



Figure 15-27 PWM mode 2, center-aligned, two-point comparison

#### Caution:

OCREFxA is output by two-point comparison, and OCREFxB is controlled by CHxCCRB for single-point comparison output.

- Step 1: Set the SYSCTRL\_APBEN2.ATIM bit to 1 and open the ATIM module;
- Step 2: Set the register ATIM\_CR.MODE to 0x3, the timer works in center-aligned mode;
- Step 3: Set the register ATIM\_CR.COMP to 0x0, set as independent PWM output;
- Step 4: Set ATIM\_ARR according to the period of PWM;
- Step 5: Set the initial value of the counter ATIM\_CNT (the initial value must be less than the value of ATIM\_ARR);
- Step 6: Set ATIM\_CR.PWM2S to 0x0 to enable the two-point comparison function;
- Step 7: Set the comparison registers ATIM\_CHxCCRA, ATIM\_CHxCCRB according to the PWM pulse width;
- Step 8: Set ATIM\_FLTR.OCMxBFLTxB and ATIM\_FLTR.OCMxAFLTxA to 0x7, so that the compare output mode is PWM mode 2;
- Step 9: Set the relevant bits of the ATIM\_ICR register and clear the relevant interrupt flag;
- Step 10: If necessary, set the relevant interrupt enable;
- Step 11: Set ATIM\_FLTR.CCPxA and ATIM\_FLTR.CCPxB to 0, no inverting output is required;
- Step 12: Set ATIM\_DTR.MOE to 0x01 to enable PWM output;
- Step 13: Set the register ATIM\_CR.EN to 0x01 to enable the timer.

## 15.3.3.5 Complementary PWM output and dead-time insertion

ATIM can output three complementary PWM signals, and can set dead-time.

Set the COMP bit field of the control register ATIM\_CR to 1 to select the complementary PWM output mode, and compare the output channel CHxA and channel CHxB to generate a pair of complementary PWM. Set the OCMxAFLTxA bit field of the ATIM\_FLTR register to 0x6 to select PWM mode 1, and to 0x7 to select PWM mode 2. Set the MOE bit field of the ATIM\_DTR register to 1 to enable the PWM output.

Complementary PWM output mode, single-point comparison or two-point comparison can be selected through the PWM2S bit field of the control register ATIM\_CR: use the comparison capture register ATIM\_ CHxCCRA to control the comparison output in single-point comparison; use the comparison capture register ATIM\_CHxCCRA and ATIM\_CHxCCRB to control the two-point comparison Compare output.

In complementary PWM output mode, channel A of channel CHx controls the output signal, and channel B compare capture register CHxCCRB no longer controls the CHxB output, but can still be used for internal control, such as triggering ADC or DMA.



Figure 15-28 Complementary PWM output waveform





Set the DTEN bit field of the dead-time register ATIM\_DTR to 1 to enable dead-time control.

The dead time of the three channels CHx is set uniformly and configured by the DTR bit field of the ATIM\_DTR register, as shown in the following table:



Table 15-9 Dead-time settings of three channels CHx

| ATIM_DTR.DTR   | Step length          | Dead-time (unit: T <sub>TCLK</sub> ) | When T <sub>TCLK</sub> = 125 ns,<br>dead-time range |
|----------------|----------------------|--------------------------------------|-----------------------------------------------------|
| DTR[7] = 0     | 1 T <sub>TCLK</sub>  | DTR[6:0] + 2                         | 0.25 ~ 16.125 μs                                    |
| DTR[7:6] = 10  | 2 T <sub>TCLK</sub>  | (DTR[5:0] + 64)×2+2                  | 16.25 ~ 32 μs                                       |
| DTR[7:5] = 110 | 8 T <sub>TCLK</sub>  | (DTR[4:0] + 32)×8+2                  | 32.5 ~ 63.25 μs                                     |
| DTR[7:5] = 111 | 16 T <sub>TCLK</sub> | (DTR[4:0] + 32)×16+2                 | 63.25 ~ 126.25 μs                                   |

#### 15.3.3.6 Brake function

Set the BKE bit field of the dead-time register ATIM\_DTR to 1 to enable the brake function.

The brake signal is active at high level. When the brake signal is active, the compare output channel CHxy will be immediately set to the output state set by the program. The specific output state is set by the BSKA and BSKB bit fields of the channel control register ATIM\_CHxCR. The common brake control is BSKA and BAKB are high or low at the same time.

## Brake trigger source

- Software brake, set the BG bit field of the control register ATIM\_CR to 1 to trigger the software brake, and the BG bit is automatically cleared
- The compare output of the voltage comparator VC, the VCE bit field of the ATIM\_DTR register is 1 to enable
- System abnormality, such as: abnormal clock, abnormal power supply, etc., the SAFEEN bit field of the ATIM\_DTR register is 1 to enable
- External ATIM\_BK pin input (GPIO function multiplexing setting), filter and set the brake input signal through the FLTBK bit field of the ATIM\_FLTR register, and select the phase of the brake input signal in the BKP bit field of the ATIM\_FLTR register

When the brake signal is valid, the brake interrupt flag ATIM\_ISR.BIF will be set by hardware. If the brake interrupt is enabled (set ATIM\_CR.BIE to 1), an interrupt request will be generated. Set ATIM\_ICR.BIF to 0 to clear the flag.

## 15.3.3.7 Compare match interrupt

After the ATIM timer is started, the count register ATIM\_CNT and the compare/capture register ATIM\_CHxCCRy begin to compare, when the two values are equal, a compare match event will be generated.

When working in edge-aligned mode, regardless of whether the counting direction is up or down, when a compare match occurs, the capture/compare match flag bit ATIM\_ISR.CxyF of the corresponding channel will be set by hardware, if interrupts are enabled (set ATIM\_CHxCR.CIEy to 1), an interrupt request will be generated, set ATIM\_ICR.CxyF to 0 to clear this flag.

When working in the center-aligned mode, the timing of the compare match interrupt of channel A and channel B of the compare channel is different:

- The channel A of compare channel is controlled by the CISA bit field of the control register ATIM\_CR, and the timing of the compare match interrupt can be selected in the process of upcounting, downcounting or bidirectional counting. When the comparison matches, the capture/compare match flag bit ATIM\_ISR. CXAF of the corresponding channel will be set by hardware. If the interrupt is enabled (set ATIM\_CHXCR. CIEA to 1), an interrupt request will be generated, set ATIM\_ICR.CXAF to 0 to clear the flag bit.
- The channel B of compare channel is controlled by the CISB bit field of the channel x control register ATIM\_CHxCR, and the timing of the compare match interrupt can be selected in the process of upcounting, downcounting or bidirectional counting. When the comparison matches, the capture/compare match flag bit ATIM\_ISR.CxBF of the corresponding channel will be set by hardware, if the interrupt is enabled (set ATIM\_CHxCR.CIEB to 1), an interrupt request will be generated, set ATIM\_ICR.CxBF to 0 to clear the flag bit . The compare match of channel B of the compare channel is controlled independently, which can trigger the ADC more flexibly. For details, see section 15.3.5 Trigger ADC.

Whether to generate an Counting Operating mode Channel A/B CISA/CISB bit fields interrupt on a compare direction match Edge-aligned mode Channel A/B Down/up Yes CISA=01 or 11 Yes Up CISA=10 or 00 No Channel A CISA=10 or 11 Yes Down CISA=01 or 00 No Center-aligned mode CISB=01 or 11 Yes Up CISB=10 or 00 No ChannelB CISB=10 or 11 Yes Down CISB=01 or 00 No

Table 15-10 Compare match interrupt settings

The example of interrupt generated by compare match is shown in the following figure:



Figure 15-30 Edge-aligned mode compare match interrupt





## 15.3.4 Quadrature encoding counting

When ATIM works in slave mode, it has the function of Quadrature encoding countinginging. It connects the external quadrature encoder through CH1A and CH1B. According to the jump sequence of the input signal, the counter can automatically count up or down. Its functional block diagram is shown in the following figure:



Figure 15-32 Quadrature encoding counting

The CH1A and CH1B input signals have filtering function, which are set by the OCM1AFLT1A and OCM1BFLT1B bit fields of the ATIM\_FLTR register respectively; the configurable phase is controlled by the CCP1A and CCP1B bit fields of the ATIM\_FLTR register respectively.

IAFP and IBFP are the internal signal names of CH1A and CH1B after filtering and phase selection, which are used as the input signal interface of the encoder. The phase relationship between IAFP and IBFP determines the counting direction, and also affects the direction bit field DIR of the control register ATIM\_CR.

The SMS bit fields of the master-slave mode control register ATIM\_MSCR are 0x4, 0x5, and 0x6, which correspond to orthogonal encoding mode 1, mode 2, and mode 3 respectively. Quadrature encoding mode 1 uses the edge counting of CH1A; mode 2 uses the edge counting of CH1B; mode 3 uses the edge counting of CH1A and CH1B. The relationship between the counting direction and the encoder signal in the three modes of quadrature encoding is shown in the following table:

Signal level **IAFP IBFP** Mode **IAFP IBFP** Rising Falling Rising Falling High Downcounting Upcounting No count No count Mode 1 Low Downcounting No count No count Upcounting High No count No count Upcounting Downcounting Mode 2 Low No count No count Downcounting Upcounting Downcounting Upcounting High High Upcounting Downcounting Mode 3 Low Low Upcounting Downcounting Downcounting Upcounting

Table 15-11 Quadrature encoding mode counting direction

#### Caution:

To ensure the correctness of counting direction and speed, the phase difference between CH1A and CH1B should be greater than one TCLK pulse width; the signal pulse width of CH1A or CH1B should be greater than two TCLK pulse widths.

The following figure is an example of encoding count operation, showing the generation and direction control of the count signal. (It also shows how to suppress input jitter when counting on both edges in center-aligned mode, which typically occurs when the encoder switches directions.)

The example configuration is as follows:

- CH1A is filtered and non-inverted into CH1CCRA
- CH1B is filtered and non-inverted into CH1CCRB
- Set the SMS bit field of the TIM\_MSCR register to 0x6, select the quadrature encoding mode to 3, and count the rising and falling edges of CH1A and CH1B.
- Set ATIM\_CR.EN to 0x01, start counter

Forward Jitter Backward Jitter Forward

CH1A

CH1B

Up

Down

Up

Up

Figure 15-33 Encoding counting operation example



298 / 572

**Rev 1.0** 

## 15.3.5 Trigger ADC

Both ATIM edge-aligned and center-aligned modes support compare match events or update events to trigger the ADC. The ADC trigger function can be applied to motor FOC control.

Set the ADTE bit field of the trigger ADC control register ATIM\_TRIG to 1, enable the ADC trigger global control, and allow the ADC to be triggered when a compare match or event update occurs.

Set ATIM\_TRIG.UEVE to 1, and the ADC will be triggered synchronously when the update event occurs.

Set ATIM\_TRIG.CMxyE to 1 to trigger the ADC when the channel CHxy compare match occurs. For the timing of the compare match, please refer to section *15.3.3.7 Compare match interrupt*.

#### 15.3.6 DMA function

Both edge-aligned and center-aligned modes of ATIM support capture/compare or timer overflow trigger DMA. Using the DMA function, data can be written to the timer from other locations, or read from the timer and written to other locations. For example, it can be applied to automatic transfer of data after data capture and changing the period or pulse width of PWM output.

When ATIM works in compare mode, the CCDS bit field of the master/slave mode control register ATIM\_MSCR is 0, and the comparison match triggers DMA. The CCDS bit field is 1. DMA is not triggered by comparison matching, but by event update.

The compare/capture channels CH1~3 of ATIM allow the DMA function to be triggered when a capture or compare match occurs. The compare channel CH4 has no input port and can only trigger the DMA function when a compare match occurs.

To trigger DMA using capture/compare, you need to set the HARDSRC bit field of the DMA trigger source control register DMA\_TRIG to 0x11 or 0x12. As shown in the following table:

| HARDSRC bit fields | DMA trigger sources                                               | DMA numbe |
|--------------------|-------------------------------------------------------------------|-----------|
| 010001             | CH1A, CH2A, CH3A, CH4 compare/capture flags, or event update flag | 0x11      |
| 010010             | CH1B, CH2B, CH3B compare/capture flags, or event update flag      | 0x12      |

Table 15-12 DMA trigger sources

The compare channels CH1A, CH2A, CH3A and CH4 share the DMA request source numbered 17, and the compare channels CH1B, CH2B and CH3B share the DMA request source numbered 18. For details, please refer to section 8.8.4 DMA\_TRIGy channel y trigger suorce control register.

#### 15.3.7 Slave mode

The slave mode of the ATIM timer means that the operation mode of the timer is controlled by the trigger signal. The SMS bit field of the master-slave mode control register ATIM\_MSCR can set the different working states of the ATIM timer in the slave mode. As shown in the following table:

Table 15-13 Working status of slave mode

| _             |                                     |
|---------------|-------------------------------------|
| ATIM_MSCR.SMS | Slave mode function selection       |
| 000           | Use internal clock                  |
| 001           | Reset function                      |
| 010           | Trigger mode                        |
| 011           | External clock mode                 |
| 100           | Quadrature encoding counting mode 1 |
| 101           | Quadrature encoding counting mode 2 |
| 110           | Quadrature encoding counting mode 3 |
| 111           | Gated function                      |

## 15.3.7.1 Use internal clock (master mode)

When the SMS bit field of the ATIM master-slave mode control register ATIM\_MSCR is 0x0, the timer slave mode is disabled. The counting clock source is selected by the CT bit field of the control register ATIM\_CR. Write 1 to the ATIM\_CR.EN bit field, and the timer starts counting immediately.

## 15.3.7.2 Reset function (slave mode)

When the SMS bit field of the ATIM master-slave mode control register ATIM\_MSCR is 0x1, the reset of the ATIM counter is controlled by the TS signal. When the TS signal is active, the ATIM counter CNT and the prescaler counter are initialized. If the URS bit field of the control register ATIM\_CR is 0, an update event UEV is generated, the update event interrupt flag bit ATIM\_ISR.UIF is set, and ATIM\_ARR, ATIM\_CHxCCRy are updated to its cache register at the same time.

The source of the TS signal is controlled by the TS bit of the master-slave mode control register ATIM\_MSCR, as shown in the following table:

| ATIM_MSCR.TS | TS signal source                                     |  |
|--------------|------------------------------------------------------|--|
| 000          | ETR filtered phase-selected signal ETFP              |  |
| 001          | Internal interconnect signal ITR                     |  |
| 101          | Input signal of port CH1A                            |  |
| 110          | Filtered and phase-selected signal IAFP at port CH1A |  |
| 111          | Filtered and phase-selected signal IBFP at port CH1B |  |

Table 15-14 TS signal sources

The source of the ETR input signal can be the external ATIM\_ETR pin or other on-chip peripherals, please refer to section *15.3.9 On-chip peripheral interconnect ETR*. When ETR is selected as the TS signal source, the filter control can be performed through ATIM\_FLTR.FLTET, and the ETR input phase can be selected through ATIM\_FLTR.ETP.

The source of the internal interconnection signal ITR is the overflow signal of BTIM and GTIM, which can be selected by the timer ITR source configuration register SYSCTRL\_TIMITR, see *Table 15-15 ATIM internal cascade ITR*.

The external input ports CH1A and CH1B both have filtering and phase selection functions. CH1A and CH1B respectively use the OCM1AFLT1A and OCM1BFLT1B bit fields of the output control/input filtering register ATIM\_FLTR for filtering control, and the CCP1A and CCP1B bit fields for phase control. The input CH1A and CH1B pins of ATIM need to be configured with multiplexing functions. For the supported pins, see *Table 15-3 ATIM compare/capture channel pins*.

## 15.3.7.3 Trigger mode (slave mode)

The SMS bit field of the ATIM master-slave mode control register ATIM\_MSCR is 0x2, which is configured as a trigger mode, and can be triggered by software or hardware to start the counter to start counting.

Software trigger

Set the TG bit field of the control register ATIM\_CR to 1, start the counter immediately, and the TG bit is automatically cleared.

Hardware trigger

When the trigger signal TS is valid, the counter is started. For TS signal source and phase selection, please refer to section *15.3.7.2 Reset function* (slave mode).

When a trigger is generated, the trigger interrupt flag bit ATIM\_ISR.TIF will be set by hardware. If the trigger interrupt enable bit ATIM\_CR.TIE is set to 1, an interrupt request will be generated, and ATIM\_ICR.TIF is set to 0 to clear the interrupt flag bit.

#### Caution:

If you use falling edge triggering, you need to select the trigger polarity first, and then select the trigger mode to avoid false triggering.

## 15.3.7.4 External clock mode (slave mode)

The SMS bit of the master-slave mode control register ATIM\_MSCR is 0x3, and the ATIM counter counts on each valid edge of the TS signal. For TS signal source and phase selection, please refer to section *15.3.7.2 Reset function (slave mode)*.

#### Caution:

In this mode, ATIM CR.EN must be set to 1 to enable the timer.

## 15.3.7.5 Quadrature encoding mode (slave mode)

The SMS bits of the master-slave mode control register ATIM\_MSCR are 0x4~0x6. The counter counts up or down according to the transition sequence of the channel CH1A and CH1B input signals. For details, please refer to section 15.3.4 Quadrature encoding counting.

## 15.3.7.6 Gated function (slave mode)

The SMS bit field of the master-slave mode control register ATIM\_MSCR is 0x7, and the ATIM is configured in gated mode. When the gate control signal TS is valid and ATIM\_CR.EN is 1, the counter starts counting; when the gate control signal TS is invalid or ATIM\_CR.EN is 0, the counter counting is suspended.

For TS signal source and phase selection, please refer to section 15.3.7.2 Reset function (slave mode).



#### 15.3.8 Internal cascade ITR

All timers (ATIM, GTIM, BTIM) of CW32W031 can be used in cascade, and the overflow signal of the previous timer is used as the ITR input of the next timer.

The ITR source of ATIM is the overflow signal of BTIM and GTIM, which can be selected by the timer ITR source configuration register SYSCTRL\_TIMITR, as shown in the following table:

SYSCTRL\_TIMITR.ATIMITR ITR signal sources of ATIM 000 Overflow signal of BTIM1 001 Overflow signal of BTIM2 010 Overflow signal of BTIM3 011 Overflow signal of GTIM1 100 Overflow signal of GTIM2 101 Overflow signal of GTIM3 110 Overflow signal of GTIM4

Table 15-15 ATIM internal cascade ITR

ATIM can also serve as an ITR source for BTIM and GTIM. Through the MMS bit field of the master-slave mode control register ATIM\_MSCR, the master mode output of the ATIM can be selected and connected to the ITR input of other timers. As shown in the following figure:



Figure 15-34 ATIM internal cascade ITR

Table 15-16 ATIM master mode output selection

| ATIM_MSCR.MMS | ATIM master mode output                             |
|---------------|-----------------------------------------------------|
| 000           | Software update UG, write ATIM_CR.UG                |
| 001           | Timer enable signal EN (ATIM_CR.EN)                 |
| 010           | Timer update event UEV                              |
| 011           | Compare match select output CMPSO                   |
| 100           | Timer channel CH1A compare reference output OCREF1A |
| 101           | Timer channel CH2A compare reference output OCREF2A |
| 110           | Timer channel CH3A compare reference output OCREF3A |
| 111           | Timer channel CH1B compare reference output OCREF1B |

## 15.3.9 On-chip peripheral interconnect ETR

The source of the ETR signal of ATIM can be the ATIM\_ETR pin or other on-chip peripherals, which can be selected through the advanced timer ETR source configuration register SYSCTRL\_ATIMETR.

When SYSCTRL\_ATIMETR.ATIMETR is 0x00, the ETR signal comes from the ATIM\_ETR pin input; when ATIMETR is 0x01~0x06, the ETR signal comes from other on-chip peripherals to realize the interconnection between on-chip and peripherals, as shown in the following table:

Table 15-17 ETR sources of ATIM

| SYSCTRL_ATIMETR.ATIMETR | ETR sources of ATIM                     |
|-------------------------|-----------------------------------------|
| 000                     | Configured by GPIOx_AFRH and GPIOx_AFRL |
| 001                     | RXD signal of UART1                     |
| 010                     | RXD signal of UART2                     |
| 011                     | RXD signal of UART3                     |
| 100                     | Compare output signal of VC1            |
| 101                     | Compare output signal of VC2            |
| 110                     | LVD output signal                       |

## 15.4 Debugging support

ATIM supports stop or continue counting in debug mode, which is set by the ATIM bit field of the debug status timer control register SYSCTRL\_DEBUG.

Set SYSCTRL\_DEBUG.ATIM to 1, then suspend the counter count of ATIM in the debug state;

If SYSCTRL\_DEBUG.ATIM is set to 0, the counter of ATIM continues to count in the debug state.



## 15.5 Programming examples

## 15.5.1 Input capture

The following example shows how to capture the counter value into the ATIM\_CH1CCRA register on the rising edge of the CH1A input signal, the steps are as follows:

- Step 1: Set the SYSCTRL\_APBEN2.ATIM bit to 1 and open the ATIM module;
- Step 2: Set the MODE bit of the register ATIM\_CR to 0x02, so that the counting mode of the ATIM is edgealigned mode, so that the ATIM can work in the input capture mode;
- Step 3: Set the CSA bit of the register ATIM\_CH1CR to 0x01, and configure CH1A to be the input capture mode;
- Step 4: Set the BKSA bit of the register ATIM\_CH1CR to 0x01, and configure the CH1A rising edge capture;
- Step 5: According to the characteristics of the input signal, set the FLT1A bit of the ATIM\_FLTR register, and configure the input filter to the required bandwidth;
- Step 6: Set the relevant bits of the ATIM\_ICR register to 0, and clear the flag to prevent the previous setting from affecting the result of this operation;
- **Step 7:** According to the characteristics of the input signal, set the value of the ATIM\_ARR register, and select the appropriate auto-reload value;
- Step 8: Set the EN bit of the ATIM\_CR register to 0x01 to allow the capture of the counter value into the capture register;
- Step 9: If required, enable the relevant interrupt request by setting the CIEA bit in the ATIM\_CH1CR register and enable the DMA request by setting the CDEA bit in the ATIM\_CH1CR register.

## 15.5.2 PWM input

The following example shows how to measure the pulse width and period of the PWM signal input from the CH3B channel. The steps are as follows:

- Step 1: Set the SYSCTRL\_APBEN2.ATIM bit to 1 and open the ATIM module;
- Step 2: Set the MODE bit of the register ATIM\_CR to 0x02, so that the counting mode of the ATIM is edgealigned mode, so that the ATIM can work in the input capture mode;
- Step 3: Set the CSB bit of register ATIM\_CH3CR to 0x01, and configure CH3B as input capture mode;
- Step 4: Set the BKSB bit of the register ATIM\_CH3CR to 0x11, and configure CH3B rising/falling edge capture;
- Step 5: According to the characteristics of the input signal, set the FLT3B bit of the ATIM\_FLTR register, and configure the input filter to the required bandwidth;
- Step 6: Set the relevant bits of the ATIM\_ICR register to 0, and clear the flag to prevent the previous setting from affecting the result of this operation;
- Step 7: According to the characteristics of the input signal, set the value of the ATIM\_ARR register, and select the appropriate auto-reload value;
- Step 8: Set the EN bit of the ATIM\_CR register to 0x01 to allow the capture of the counter value into the capture register;
- Step 9: If required, enable the relevant interrupt request by setting the CIEA bit in the ATIM\_CH3CR register;
- Step 10: Wait for the capture to occur three times, read the value captured in the ATIM\_CH3CCRB register after each capture occurs, and clear the capture interrupt flag bit;
- Step 11: According to the value of the ATIM\_CH3CCRB register read three times, it can be obtained that the period of PWM is the third value-first value, and the pulse width of PWM is the third value-first value or the second value- 1st value.



## 15.5.3 Output compare function

Configuration steps for output compare mode:

- **Step 1**: Select the counter clock (internal, external, prescaler);
- Step 2: Write the corresponding data into the ATIM\_ARR and ATIM\_CHxCCRy registers;
- Step 3: If an interrupt request is to be generated, set the CIEy bit in the ATIM\_CHxCR register;
- Step 4: Select the output mode, if you need to flip the output, set ATIM\_FLTR.OCMxy=0x4;
- Step 5: Set the CSy bit in the ATIM\_CHxCR register to use the corresponding channel as a compare output;
- Step 6: Clear the relevant interrupt flag;
- Step 7: Set the CCPxy bit in the ATIM\_FLTR register to select the desired output phase;
- Step 8: Set the EN bit in the ATIM\_CR register to start the counter.

## 15.5.4 Complementary PWM output

The steps to set up a center-aligned complementary PWM output with dead-time are as follows:

- Step 1: Set the SYSCTRL\_APBEN2.ATIM bit to 1 and open the ATIM module;
- Step 2: Set the register ATIM\_CR.MODE to 0x3, the timer works in center-aligned mode;
- Step 3: Set the register ATIM\_CR.COMP to 0x01, and select the complementary PWM output;
- Step 4: Set the register ATIM CR.PWM2S to 0x0 and use the two-point compare function;
- Step 5: Set ATIM\_ARR according to the period of PWM;
- Step 6: Set the initial value of the counter ATIM\_CNT (the initial value must be less than the value of ATIM\_ARR);
- Step 7: Set the compare registers ATIM\_CHxCCRA and ATIM\_CHxCCRB according to the PWM pulse width;
- Step 8: Set ATIM\_FLTR.OCMxBFLTxB and ATIM\_FLTR.OCMxAFLTxA to 0x6 or 0x7 to make the compare output mode PWM mode 1 or PWM mode 2;
- Step 9: Set the relevant bits of the ATIM\_ICR register and clear the relevant interrupt flag;
- Step 10: If necessary, set the relevant interrupt enable;
- Step 11: Set ATIM\_FLTR.CCPxA and ATIM\_FLTR.CCPxB to 0, no inverting output is required;
- Step 12: Set ATIM\_DTR.DTEN to 0x01 to enable dead-time insertion;
- Step 13: Set ATIM\_DTR.DTR, and configure the inserted dead-time duration;
- Step 14: Set ATIM DTR.MOE to 0x01 to enable PWM output;
- Step 15: Set the register ATIM\_CR.EN to 0x01 to enable the timer.



#### 15.5.5 DMA function

## The configuration steps for capturing DMA data transfer on the rising edge of CH1A are as follows:

- Step 1: Set the SYSCTRL\_APBEN2.ATIM bit to 1 and open the ATIM module;
- Step 2: Set the SYSCTRL\_AHBEN.DMA bit to 1 and open the DMA module;
- Step 3: Set DMA\_CSRy.TRANS to 1 to make DMA work in BLOCK transfer mode;
- Step 4: Set the DMA data transfer bit width (DMA\_CSRy.SIZE), the source address increment mode (DMA\_CSRy. SRCINC) and the destination address increment mode (DMA\_CSRy.DSTINC) of the DMA channel;
- Step 5: Set the DMA transfer data block size (DMA\_CNTy.REPEAT, please keep it as 1) and the number of transfer data blocks (DMA\_CNTy.CNT);
- Step 6: Set the source and destination addresses (DMA\_SRCADDRy and DMA\_DSTADDRy);
- Step 7: Set DMA\_CSRy.EN to 1 to enable the corresponding DMA channel;
- Step 8: Set DMA\_TRIGy.TYPE to 1, make DMA work in hardware trigger transmission mode, and set hardware trigger source DMA\_TRIGy.HARDSRC to 0x11;
- Step 9: Set the MODE bit of the register ATIM\_CR to 0x02, so that the counting mode of the ATIM is edgealigned mode, so that the ATIM can work in the input capture mode;
- Step 10: Set the CSA bit of the register ATIM\_CH1CR to 0x01, and configure CH1A to be the input capture mode;
- Step 11: Set the BKSA bit of the register ATIM\_CH1CR to 0x01, and configure CH1A rising edge capture;
- Step 12: According to the characteristics of the input signal, set the FLT1A bit of the ATIM\_FLTR register, and configure the input filter to the required bandwidth;
- Step 13: Set the relevant bits of the ATIM\_ICR register to 0, and clear the flag to prevent the previous setting from affecting the result of this operation;
- Step 14: According to the characteristics of the input signal, set the value of the ATIM\_ARR register, and select the appropriate auto-reload value;
- Step 15: Set the EN bit of the ATIM\_CR register to 0x01 to allow the capture of the counter value into the capture register;
- Step 16: If required, enable the relevant interrupt request by setting the CIEA bit in the ATIM\_CH1CR register;
- Step 17: Set the CDEA bit in the ATIM\_CH1CR register to enable DMA requests.

#### Caution:

The source address is set to the address of the ATIM\_CH1CCRA register, the source address is fixed, and the destination address is incremented automatically.



## DMA data transfer changes the pulse width of the PWM output

- Step 1: Set DMA\_CSRy.TRANS to 1 to make DMA work in BLOCK transfer mode;
- Step 2: Set the DMA data transfer bit width (DMA\_CSRy.SIZE), the source address increment mode (DMA\_CSRy. SRCINC) and the destination address increment mode (DMA\_CSRy.DSTINC) of the DMA channel;
- Step 3: Set the DMA transfer data block size (DMA\_CNTy.REPEAT, please keep it as 1) and the number of transfer data blocks (DMA\_CNTy.CNT);
- Step 4: Set the source and destination addresses (DMA\_SRCADDRy and DMA\_DSTADDRy);
- Step 5: Set DMA\_CSRy.EN to 1 to enable the corresponding DMA channel;
- Step 6: Set DMA\_TRIGy.Type to 1, make DMA work in hardware trigger transmission mode, and set hardware trigger source DMA\_TRIGy.HardSrc as hardware trigger source No.18;
- Step 7: Set the register ATIM\_CR.MODE to 0x2, the timer works in edge-aligned mode;
- Step 8: Set the register ATIM\_CR.DIR to 0x0, and the edge-aligned counting direction is upcounting;
- Step 9: Set ATIM\_ARR according to the period of PWM;
- Step 10: Set the initial value of the counter ATIM\_CNT (the initial value must be less than the value of ATIM\_ARR);
- Step 11: Set the compare register ATIM\_CHxCCRA according to the PWM pulse width;
- Step 12: Set ATIM\_FLTR.OCMxA to 0x7, so that the compare output mode is PWM mode 2;
- Step 13: Set the relevant bits of the ATIM\_ICR register and clear the relevant interrupt flag;
- Step 14: If necessary, set the relevant interrupt enable;
- **Step 15:** Set ATIM\_FLTR.CCPxA to 0, no inverting output is required;
- Step 16: Set ATIM\_DTR.MOE to 0x01 to enable PWM output;
- Step 17: Set the CDEA bit in the ATIM\_CHxCR register to enable DMA requests;
- **Step 18:** Set the register ATIM CR.EN to 0x01 to enable the timer.

#### Caution:

The destination address is the address of the ATIM\_CHxCCRy register, the source address is incremented automatically, and the destination address is fixed.

## 15.5.6 Trigger mode

The following is an example of the counter starting to count up on the rising edge of the CH1B input:

- Step 1: Set ATIM\_FLTR.FLT1B to 0x00, and configure the bandwidth of the input filter (in this example, no filtering is required);
- Step 2: Set ATIM\_FLTR.CCP1B to 0, select polarity (rising edge);
- Step 3: Set the SMS bit of ATIM\_MSCR to 0x2, and configure the timer as the trigger mode of slave mode;
- Step 4: Set the TS bit of ATIM\_MSCR to 0x7, and select CH1B as the input trigger source.

#### Caution:

If you use falling edge triggering, you need to select the trigger polarity first, and then select the trigger mode to avoid false triggering.



#### 15.5.7 Gated Mode

The following is an example of the counter counting up when the CH1A input is low:

- Step 1: Set ATIM\_FLTR.FLT1A to 0x00, and configure the bandwidth of the input filter (in this example, no filtering is required);
- Step 2: Set ATIM\_FLTR.CCP1A to 0x1, select polarity (low level);
- Step 3: Set the SMS bit of ATIM\_MSCR to 0x7, and configure the timer to be the gated mode of the slave mode;
- Step 4: Set the TS bit of ATIM\_MSCR to 0x6, and select CH1A as the input trigger source;
- Step 5: Set EN of ATIM\_CR to 0x1 to enable counting. When the input level of CH1A is low, the counter starts to count the internal clock, and when the input level becomes high, the counter stops counting.

#### 15.5.8 Internal cascade ITR

In this example, the enable bit EN of ATIM is used to trigger the start of BTIMx to realize the synchronous start of ATIM and BTIMx. The operation steps are as follows:

**Step 1**: Set the SYSCTRL\_APBEN2.BTIM bit to 1, and open the configuration clock of the BTIM1-3 module; *Caution:* 

BTIM1-3 share the SYSCTRL APBEN2.BTIM bit.

- Step 2: Configure BTImx\_BCR.TRS to 1, and select the trigger source from the internal cascade signal;
- Step 3: Configure BTMx\_BCR.PSC and select the prescaler ratio;
- Step 4: Configure BTIMx\_BCR.ONESHOT to select single or continuous counting mode. When configured as 0, it is continuous counting mode; when configured as 1, it is single counting;
- Step 5: If you want the trigger event to trigger an interrupt, configure BTIMx\_IER.IT to 1;
- Step 6: If you want the ARR overflow event to trigger an interrupt, configure BTIMx\_IER.OV to 1;
- Step 7: Configure the BTIMx\_ARR register and select the BTIMx count overflow time;
- Step 8: Configure BTIMx BCR.MODE to 0x10, select BTIMx to work in trigger start mode;
- Step 9: Set the system control register SYSCTRL\_APBEN2.ATIM bit to 1, and open the ATIM module;
- Step 10: Configure ATIM\_MSCR.MMS as 0x01, select ATIM main mode to output CTEN;
- Step 11: Set the register ATIM\_CR.MODE to 0x2, the timer works in edge-aligned mode;
- Step 12: Set the register ATIM\_CR.DIR to 0x0, and the edge-aligned counting direction is upcounting;
- **Step 13:** Set ATIM\_ARR according to the period;
- Step 14: Set the register ATIM\_CR.EN to 0x1, which will start ATIM and BTIMx synchronously.



# 15.6 List of registers

ATIM base address: ATIM\_BASE = 0x4001 2C00

Table 15-18 List of ATIM registers

| Register name | Register address | Register description                 |
|---------------|------------------|--------------------------------------|
| ATIM_ARR      | ATIM_BASE + 0x00 | Reload register                      |
| ATIM_CNT      | ATIM_BASE + 0x04 | Count register                       |
| ATIM_CR       | ATIM_BASE + 0x0C | Control register                     |
| ATIM_ISR      | ATIM_BASE + 0x10 | Interrupt flag register              |
| ATIM_ICR      | ATIM_BASE + 0x14 | Interrupt flag clear register        |
| ATIM_MSCR     | ATIM_BASE + 0x18 | Master-slave mode control register   |
| ATIM_FLTR     | ATIM_BASE + 0x1C | Output control/Input filter register |
| ATIM_TRIG     | ATIM_BASE + 0x20 | Trigger ADC control register         |
| ATIM_CH1CR    | ATIM_BASE + 0x24 | Channel 1 control register           |
| ATIM_CH2CR    | ATIM_BASE + 0x28 | Channel 2 control register           |
| ATIM_CH3CR    | ATIM_BASE + 0x2C | Channel 3 control register           |
| ATIM_CH4CR    | ATIM_BASE + 0x58 | Channel 4 control register           |
| ATIM_DTR      | ATIM_BASE + 0x30 | Dead-time register                   |
| ATIM_RCR      | ATIM_BASE + 0x34 | Repeat count register                |
| ATIM_CH1CCRA  | ATIM_BASE + 0x3C | Channel 1 compare/capture register A |
| ATIM_CH1CCRB  | ATIM_BASE + 0x40 | Channel 1 compare/capture register B |
| ATIM_CH2CCRA  | ATIM_BASE + 0x44 | Channel 2 compare/capture register A |
| ATIM_CH2CCRB  | ATIM_BASE + 0x48 | Channel 2 compare/capture register B |
| ATIM_CH3CCRA  | ATIM_BASE + 0x4C | Channel 3 compare/capture register A |
| ATIM_CH3CCRB  | ATIM_BASE + 0x50 | Channel 3 compare/capture register B |
| ATIM_CH4CCR   | ATIM_BASE + 0x54 | Channel 4 compare/capture register   |

# 15.7 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

## 15.7.1 ATIM\_CR control register

Address offset: 0x0C Reset value: 0x0060 0008

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                        |
| 29        | UNDE | RW         | Underflow interrupt enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                  |
| 28        | OVE  | RW         | Overflow interrupt enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                   |
| 27        | DIR  | RW/RO      | Counting direction, only writable in edge-aligned mode. Read only in other modes, write invalid 0: Upcounting 1: Downcounting Caution: DIR is automatically cleared to 0 when switching from other modes to center-aligned mode. Software event update and slave mode externally triggered reset mode DIR is automatically cleared. |
| 26        | BG   | RW         | Software brake, automatic reset Write 1 to generate software brake Write 0 invalid                                                                                                                                                                                                                                                  |
| 25        | UG   | RW         | Software update, auto reset Write 1 to generate a software update Write 0 invalid Caution: After software update, initialize the counter and update ATIM_ARR, ATIM_CHxCCRy to its cache register (cache enable), the prescaler counter will also be cleared.                                                                        |
| 24        | TG   | RW         | Triggered by software, automatically cleared. It needs to be triggered in trigger mode (SMS=2) and MODE=2/3. Write 1 to generate software trigger Write 0 invalid                                                                                                                                                                   |
| 23        | OCCE | RW         | OCREF clear enabled 0: OCREF output is not affected by OCREF_CLR 1: OCREF_CLR high level signal can clear OCREF output                                                                                                                                                                                                              |

| Bit field | Name    | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                      |
|-----------|---------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22:21     | CISA    | RW         | In center-aligned mode, compare match interrupt settings for all A channels 00: No interrupt 01: Generate interrupt on match while counting up 10: Generate interrupt on match while counting down 11: Interrupt on match when up and down counting Caution: In center-aligned mode, the compare match interrupt of the B channel is set in the CISB bit field of the ATIM_CHxCR register |
| 20        | BIE     | RW         | Brake interrupt enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                            |
| 19        | TIE     | RW         | Trigger interrupt enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                          |
| 18        | RFU     | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                              |
| 17        | URS     | RW         | Update source 0: Overflow/underflow/software update UG/slave mode reset 1: Overflow/underflow                                                                                                                                                                                                                                                                                             |
| 16        | occs    | RW         | OCREF clear source selection 0: Voltage comparator VC output, VC selection is set in VCx_CR1 register 1: The ETR port filters the phase-selected signal Caution: When OCCE is valid, the OCREF_CLR high level signal can clear the compare output signal of OCREF to zero (valid when OCMxyFLTxy>1), and continue to compare output after the next update event UEV.                      |
| 15        | RFU     | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                              |
| 14        | ONESHOT | RW         | Single trigger mode selection 0: Loop count 1: Timer stops after event update occurs                                                                                                                                                                                                                                                                                                      |
| 13:12     | MODE    | RW         | Working mode 00: Reserved 10: Edge-aligned mode 11: Center-aligned mode                                                                                                                                                                                                                                                                                                                   |
| 11        | RFU     | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                              |
| 10        | UIE     | RW         | UIE update interrupt enabled<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                 |
| 9:8       | RFU     | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                              |



| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                 |
|-----------|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7         | BUFPEN | RW         | Reload register cache enabled  0: The cache is invalid, and the period value is affected immediately after writing  1: The cache is enabled, and the period value will not be affected until the next event is updated after writing                                                                 |
| 6:4       | PRS    | RW         | Internal clock PCLK frequency division selection 000: 1 001: 2 010: 4 011: 8 100: 16 101: 32 110: 64 111: 256                                                                                                                                                                                        |
| 3         | PWM2S  | RW         | OCREFA two-point compare selection (default is 1) 0: Two-point compare enabled, use CHxCCRA, CHxCCRB compare to control OCREFA output 1: Single-point compare enabled, use only CHxCCRA compare to control OCREFA output Caution: OCREFB is not affected, still use CHxCCRB to control OCREFB output |
| 2         | СТ     | RW         | Count clock selection 0: Internal count clock PCLK 1: External count clock ETR                                                                                                                                                                                                                       |
| 1         | COMP   | RW         | PWM complementary output mode selection 0: Independent PWM output 1: Complementary PWM output                                                                                                                                                                                                        |
| 0         | EN     | RW         | Timer enabled 0: Disabled 1: Enabled Caution: It can be enabled by external trigger, and this bit is automatically cleared when the ONESHOT mode ends.                                                                                                                                               |

## 15.7.2 ATIM\_ARR reload register

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                           |
|-----------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                   |
| 15:0      | ARR  | RW         | Reload register/period register with cache function When the counter is not enabled or the cache is not enabled, the cache register can be updated immediately |

## 15.7.3 ATIM\_CNT count register

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | CNT  | RW         | Reload timer count register                  |

## Caution:

When using the PWM compare output, the initialized CNT value needs to be smaller than the ARR value.

## 15.7.4 ATIM\_ISR interrupt flag register

Address offset: 0x10 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                   |
|-----------|------|------------|------------------------------------------------------------------------|
| 31:19     | RFU  | -          | Reserved bits, please keep the default value                           |
| 18        | C4AF | RO         | Channel CH4 compare match flag                                         |
| 17        | UNDF | RO         | Underflow interrupt flag                                               |
| 16        | OVF  | RO         | Overflow interrupt flag                                                |
| 15        | TIF  | RO         | Trigger interrupt flag                                                 |
| 14        | BIF  | RO         | Brake interruption flag                                                |
| 13        | C3BE | RO         | Channel CH3B capture data loss flag 0: No data loss 1: Data loss       |
| 12        | C2BE | RO         | Channel CH2B capture data loss flag 0: No data loss 1: Data loss       |
| 11        | C1BE | RO         | Channel CH1B capture data loss flag<br>0: No data loss<br>1: Data loss |
| 10        | C3AE | RO         | Channel CH3A capture data loss flag<br>0: No data loss<br>1: Data loss |
| 9         | C2AE | RO         | Channel CH2A capture data loss flag<br>0: No data loss<br>1: Data loss |
| 8         | C1AE | RO         | Channel CH1A capture data loss flag<br>0: No data loss<br>1: Data loss |

| Bit field | Name | Permission | Function description                                                      |
|-----------|------|------------|---------------------------------------------------------------------------|
| 7         | C3BF | RO         | Capture/compare match flag occurred on channel CH3B 0: Not occur 1: Occur |
| 6         | C2BF | RO         | Capture/compare match flag occurred on channel CH2B 0: Not occur 1: Occur |
| 5         | C1BF | RO         | Capture/compare match flag occurred on channel CH1B 0: Not occur 1: Occur |
| 4         | C3AF | RO         | Capture/compare match flag occurred on channel CH3A 0: Not occur 1: Occur |
| 3         | C2AF | RO         | Capture/compare match flag occurred on channel CH2A 0: Not occur 1: Occur |
| 2         | C1AF | RO         | Capture/compare match flag occurred on channel CH1A 0: Not occur 1: Occur |
| 1         | RFU  |            | Reserved bits, please keep the default value                              |
| 0         | UIF  | RO         | Event update interrupt flag 0: Not occur 1: Occur                         |

# 15.7.5 ATIM\_ICR interrupt flag clear register

Address offset: 0x14 Reset value: 0x0007 FFFF

| Bit field | Name | Permission | Function description                                            |
|-----------|------|------------|-----------------------------------------------------------------|
| 31:19     | RFU  | -          | Reserved bits, please keep the default value                    |
| 18        | C4AF | R1W0       | Channel CH4 compare match flag is cleared, write 0 to clear     |
| 17        | UNDF | R1W0       | Underflow interrupt flag is cleared, write 0 to clear           |
| 16        | OVF  | R1W0       | Overflow interrupt flag is cleared, write 0 to clear            |
| 15        | TIF  | R1W0       | Trigger interrupt flag to clear, write 0 to clear               |
| 14        | BIF  | R1W0       | Brake interrupt flag is cleared, write 0 to clear               |
| 13        | C3BE | R1W0       | Channel CH3B capture data loss flag clear, write 0 to clear     |
| 12        | C2BE | R1W0       | Channel CH2B capture data loss flag clear, write 0 to clear     |
| 11        | C1BE | R1W0       | Channel CH1B capture data loss flag clear, write 0 to clear     |
| 10        | C3AE | R1W0       | Channel CH3A capture data loss flag clear, write 0 to clear     |
| 9         | C2AE | R1W0       | Channel CH2A capture data loss flag clear, write 0 to clear     |
| 8         | C1AE | R1W0       | Channel CH1A capture data loss flag clear, write 0 to clear     |
| 7         | C3BF | R1W0       | Channel CH3B capture/compare match flag clear, write 0 to clear |
| 6         | C2BF | R1W0       | Channel CH2B capture/compare match flag clear, write 0 to clear |
| 5         | C1BF | R1W0       | Channel CH1B capture/compare match flag clear, write 0 to clear |
| 4         | C3AF | R1W0       | Channel CH3A capture/compare match flag clear, write 0 to clear |
| 3         | C2AF | R1W0       | Channel CH2A capture/compare match flag clear, write 0 to clear |
| 2         | C1AF | R1W0       | Channel CH1A capture/compare match flag clear, write 0 to clear |
| 1         | RFU  | -          | Reserved bits, please keep the default value                    |
| 0         | UIF  | R1W0       | Event update interrupt flag clear, write 0 to clear             |

# 15.7.6 ATIM\_MSCR master-slave mode control register

Address offset: 0x18 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 12        | IB1S | RW         | CH1B input selection 0: CH1B 1: Internal trigger TS signal                                                                                                                                                                                                                                                                                                                                                                                                           |
| 11        | IA1S | RW         | CH1A input selection 0: CH1A 1: Exclusive OR of CH1A, CH2A, CH3A Caution: After setting to 1, any port change will cause the input to change                                                                                                                                                                                                                                                                                                                         |
| 10:8      | SMS  | RW         | Select from mode function 000: Use internal clock 001: Reset function 010: Trigger mode 011: External clock mode 100: Quadrature encoding counting mode 1 101: Quadrature encoding counting mode 2 110: Quadrature encoding counting mode 3 111: Gated function                                                                                                                                                                                                      |
| 7:5       | TS   | RW         | Trigger selection 000: Filtered phase-selected signal ETFP at port ETR 001: Internal interconnect signal ITR 101: Edge signal of port CH1A 110: Filtered phase-selected signal IAFP for port CH1A 111: Filtered phase-selected signal IBFP for port CH1B                                                                                                                                                                                                             |
| 4         | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3         | CCDS | RW         | DMA trigger selection in compare mode  0: Compare match triggers DMA  1: Compare match does not trigger DMA, event updates trigger  DMA instead of compare match  Caution: Event update triggered DMA also requires the corresponding channel's DMA enable to be enabled (ATIM_CHxCR.CDEy).                                                                                                                                                                          |
| 2:0       | MMS  | RW         | Master mode output selection for internal cascade connection to ITR of other timers  000: Software update UG, write CR.UG  001: Timer enable signal EN  010: Timer update event UEV  011: Compare match selects output CMPSO  100: Timer channel CH1A compare reference output OCREF1A  101: Timer channel CH2A compare reference output OCREF2A  110: Timer channel CH3A compare reference output OCREF3A  111: Timer channel CH1B compare reference output OCREF1B |

## 15.7.7 ATIM\_FLTR output control/input filter register

Address offset: 0x1C Reset value: 0x0000 0000

| Bit field | Name           | Permission | Function description                                                                                                                                                                  |
|-----------|----------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31        | ETP            | RW         | ETR input phase selection 0: In phase 1: Reverse input                                                                                                                                |
| 30:28     | FLTET          | RW         | ETR filter settings  0xx: Invalid filtering  100: PCLK                                                                                                                                |
| 27        | ВКР            | RW         | Brake BK input phase selection 0: in phase 1: reverse input                                                                                                                           |
| 26:24     | FLTBK          | RW         | Brake input filter settings 0xx: Invalid filtering 100: PCLK 3 consecutive valid 101: PCLK /4 3 consecutive valid 110: PCLK /16 3 consecutive valid 111: PCLK /64 3 consecutive valid |
| 23        | ССР3В          | RW         | Compare function: CH3B channel compare output phase control 0: Normal output 1: Reverse output                                                                                        |
| 22:20     | OCM3B<br>FLT3B | RW         | Compare function: CH3B channel compare control, refer to OCM1BFLT1B Capture function: CH3B input channel filter setting, refer to FLTBK                                               |
| 19        | ССРЗА          | RW         | Compare function: CH3A channel compare output phase control 0: Normal output 1: Reverse output                                                                                        |
| 18:16     | OCM3A<br>FLT3A | RW         | Compare function: CH3B channel compare control, refer to OCM1BFLT1B Capture function: CH3A input channel filter setting, refer to FLTBK                                               |
| 15        | CCP2B          | RW         | Compare function: CH2B channel compare output phase control 0: Normal output 1: Reverse output                                                                                        |
| 14: 12    | OCM2B<br>FLT2B | RW         | Compare function: CH2B channel compare control, refer to OCM1BFLT1B Capture function: CH2B input channel filter setting, refer to FLTBK                                               |
| 11        | CCP2A          | RW         | Compare function: CH2A channel compare output phase control 0: Normal output 1: Reverse output                                                                                        |

| Bit field | Name           | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|----------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8      | OCM2A<br>FLT2A | RW         | Compare function: CH2A channel compare control, refer to OCM1BFLT1B Capture function: CH2A input channel filter setting, refer to FLTBK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7         | CCP1B          | RW         | Compare function: CH1B channel compare output phase control 0: Normal output 1: Reverse output CH1B port input polarity control in slave mode: 0: Normal output 1: Reverse output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6:4       | OCM1B<br>FLT1B | RW         | Compare function: CH1B channel compare control 000: Force output low 001: Force output high 010: Set to 0 on compare match 011: Set to 1 on compare match 100: Flip output on compare match 101: Output a high level for one count period on a compare match 110: PWM mode 1 Single-point comparison: CNT <chxccry cnt="" counting="" high="" level="" outputs="" up;="" when="">CHxCCRy outputs a low level when counting down. Two-point comparison: 1) CHxCCRA<cnt 2)="" 3)="" aligned="" center-aligned="" chxccra<cnt="" chxccrb="" cnt="" cnt<chxccra="" downcounting;="" edge-="" high="" level="" low="" outputs="" upcounting,="" upcounting;="" when="" ≤="">CHxCCRB outputs low level when center-aligned downcounting. 111: PWM mode 2 Single-point comparison: CNT<chxccry cnt="" counting="" level="" low="" outputs="" up;="" when="">CHxCCRy outputs a low level when counting down. Two-point comparison: 1) CHxCCRA ≤ CNT<chxccrb 2)="" 3)="" aligned="" center-aligned="" chxccra="" cnt="" cnt<chxccra="" cnt<chxccrb="" downcounting,="" downcounting;="" edge-="" high="" level="" low="" outputs="" upcounting;="" when="" ≤="">CHxCCRB outputs high level when center- aligned upcounting. Capture function: CH1B input channel filter setting, refer to FLTBK</chxccrb></chxccry></cnt></chxccry> |

| Bit field | Name           | Permission | Function description                                                                                                                                                            |
|-----------|----------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3         | CCP1A          | RW         | Compare function: CH1A channel compare output phase control 0: Normal output 1: Reverse output CH1A port input polarity control in slave mode: 0: Normal input 1: Reverse input |
| 2:0       | OCM1A<br>FLT1A | RW         | Compare function: A channel compare control, refer to OCM1BFLT1B Capture function: CH1A input channel filter setting, refer to FLTBK                                            |

## 15.7.8 ATIM\_TRIG trigger ADC control register

Address offset: 0x20 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                  |
|-----------|-------|------------|-----------------------------------------------------------------------|
| 31:8      | RFU   | -          | Reserved bits, please keep the default value                          |
| 7         | ADTE  | RW         | ADC trigger global control enabled 0: Disabled 1: Enabled             |
| 6         | СМЗВЕ | RW         | Channel CH3B compare match trigger ADC enabled 0: Disabled 1: Enabled |
| 5         | CM2BE | RW         | Channel CH2B compare match trigger ADC enabled 0: Disabled 1: Enabled |
| 4         | CM1BE | RW         | Channel CH1B compare match trigger ADC enabled 0: Disabled 1: Enabled |
| 3         | СМЗАЕ | RW         | Channel CH3A compare match trigger ADC enabled 0: Disabled 1: Enabled |
| 2         | CM2AE | RW         | Channel CH2A compare match trigger ADC enabled 0: Disabled 1: Enabled |
| 1         | CM1AE | RW         | Channel CH1A compare match trigger ADC enabled 0: Disabled 1: Enabled |
| 0         | UEVE  | RW         | Event update triggers ADC enabled 0: Disabled 1: Enabled              |

# 15.7.9 ATIM\_DTR dead-time register

Address offset: 0x30 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                            |
|-----------|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15     | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                    |
| 14        | VCE    | RW         | VC compare output brake enabled 0: Disabled 1: Enabled                                                                                                                                                                                                          |
| 13        | SAFEEN | RW         | Safety brake enabled (osc fail,brown down,lockup) 0: Disabled 1: Enabled                                                                                                                                                                                        |
| 12        | MOE    | RW         | Output compare enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                   |
| 11        | AOE    | RW         | PWM output auto-enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                  |
| 10        | BKE    | RW         | Brake enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                            |
| 9         | DTEN   | RW         | Dead-time control enabled 0: Disabled 1: Enabled Caution: Disable dead-time control when independent PWM output is enabled.                                                                                                                                     |
| 8         | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                    |
| 7:0       | DTR    | RW         | Dead-time register  DTR[7] = 0 T = DTR[6:0] + 2 2 ~ 129 step = 1  DTR[7:6] = 10 T = {DTR[5:0] + 64} × 2 + 2 130 ~ 256 step = 2  DTR[7:5] = 110 T = {DTR[4:0] + 32} × 8 + 2 258 ~ 506 step = 8  DTR[7:5] = 111 T = {DTR[4:0] + 32} × 16 + 2 514 ~ 1010 step = 16 |

## 15.7.10 ATIM\_RCR repeat count register

Address offset: 0x34 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                   |
|-----------|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                           |
| 9         | UD   | RW         | Repeat count controlled underflow shielding  0: Repeat counter count when downcounting overflows  1: Downcounting overflow shielding                                                                                                                                                                   |
| 8         | OV   | RW         | Repeat count control overflow shielding  0: Repeat counter count when upcounting overflows  1: Upcounting overflow shielding                                                                                                                                                                           |
| 7:0       | RCR  | RW         | Repeat cycle count value Set the RCR+1 cycle to be updated by the overflow controlled by [9:8], and the internal RCR_CNT is decremented by 1 when the counter overflows or underflows. When the count reaches zero, the RCR_CNT reloads the RCR value and generates an event to update the UEV signal. |

## 15.7.11 ATIM\_CH1CR channel 1 control register

Address offset: 0x24 Reset value: 0x0000 3000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|-----------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                          |  |
| 15        | CCGB | RW         | The capture/compare B channel is triggered by software, and the hardware is automatically cleared. Only interrupt is generated in compare mode Generate an interrupt in capture mode and capture the value of the counter into the capture register                                                                                                                                                                   |  |
| 14        | CCGA | RW         | The capture/compare A channel is triggered by software, and the hardware is automatically cleared. Only interrupt is generated in compare mode Generate an interrupt in capture mode and capture the value of the counter into the capture register                                                                                                                                                                   |  |
| 13:12     | CISB | RW         | In center-aligned mode, the compare match interrupt setting of the B channel  00: No interrupt  01: Interrupt is generated on match when counting up  10: Interrupt is generated on match when counting down  11: Interrupt is generated on match when counting up and down  Caution: in the center-aligned mode, the compare match interrupt of all  A channels is set in the CISA bit field of the ATIM_CR register |  |

| Bit field | Name  | Permission | Function description                                                                                                                                                                                                                                                                                                                      |  |
|-----------|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 11        | CDEB  | RW         | B channel capture compare trigger DMA enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                      |  |
| 10        | CDEA  | RW         | A channel capture compare trigger DMA enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                      |  |
| 9         | CIEB  | RW         | B channel capture compare trigger interrupt enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                |  |
| 8         | CIEA  | RW         | A channel capture compare trigger interrupt enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                |  |
| 7         | BUFEB | RW         | Compare function: compare capture register B cache enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                                  |  |
| 6         | BUFEA | RW         | Compare function: compare capture register A cache enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                                  |  |
| 5         | CSB   | RW         | B channel capture/compare function selection 0: Compare mode 1: Capture mode                                                                                                                                                                                                                                                              |  |
| 4         | CSA   | RW         | A channel capture/compare function selection 0: Compare mode 1: Capture mode                                                                                                                                                                                                                                                              |  |
| 3:2       | BKSB  | RW         | Compare mode B channel compare function output brake level control 00: High resistance output 01: No effect on output 10: Force output low level 11: Force output high level Capture mode B channel capture enabled 00: Disabled 01: Rising edge capture enabled 10: Falling edge capture enabled 11: Rising/falling edge capture enabled |  |
| 1:0       | BKSA  | RW         | Compare mode A channel compare function output brake level control 00: High resistance output 01: No effect on output 10: Force output low level 11: Force output high level Capture mode A channel capture enable 00: Disabled 01: Rising edge capture enabled 10: Falling edge capture enabled 11: Rising/falling edge capture enabled  |  |



# 15.7.12 ATIM\_CH2CR channel 2 control register

Address offset: 0x28 Reset value: 0x0000 3000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      |      |            | See ATIM_CH1CR for details                   |

## 15.7.13 ATIM\_CH3CR channel 3 control register

Address offset: 0x2C Reset value: 0x0000 3000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      |      |            | See ATIM_CH1CR                               |

## 15.7.14 ATIM\_CH4CR channel 4 control register

Address offset: 0x58 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                           |
|-----------|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                   |
| 5         | C4EN | RW         | Channel compare enable                                                                                                                                                                                                         |
| 4:3       | CIS  | RW         | In center-aligned mode, compare match interrupt setting of channel CH4  00: No interrupt  01: Interrupt on match when counting up  10: Interrupt on match when counting down  11: Interrupt on match when counting up and down |
| 2         | CDE  | RW         | Compare trigger DMA enabled 0: Disabled 1: Enabled                                                                                                                                                                             |
| 1         | CIE  | RW         | Compare trigger interrupt enabled 0: Disabled 1: Enabled                                                                                                                                                                       |
| 0         | BUFE | RW         | Compare function: channel 4 compare capture register buffer enable control 0: Disabled 1: Enabled                                                                                                                              |

## 15.7.15 ATIM\_CH1CCRA channel 1 compare capture register A

Address offset: 0x3C Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                  |
|-----------|-------|------------|-------------------------------------------------------|
| 31:16     | RFU   | -          | Reserved bits, please keep the default value          |
| 15:0      | CCR1A | RW         | Compare capture register, compare with cache function |

## 15.7.16 ATIM\_CH1CCRB channel 1 compare capture register B

Address offset: 0x40 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                  |
|-----------|-------|------------|-------------------------------------------------------|
| 31:16     | RFU   | -          | Reserved bits, please keep the default value          |
| 15:0      | CCR1B | RW         | Compare capture register, compare with cache function |

## 15.7.17 ATIM\_CH2CCRA channel 2 compare capture register A

Address offset: 0x44 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                  |
|-----------|-------|------------|-------------------------------------------------------|
| 31:16     | RFU   | -          | Reserved bits, please keep the default value          |
| 15:0      | CCR2A | RW         | Compare capture register, compare with cache function |

## 15.7.18 ATIM\_CH2CCRB channel 2 compare capture register B

Address offset: 0x48 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                  |
|-----------|-------|------------|-------------------------------------------------------|
| 31:16     | RFU   | -          | Reserved bits, please keep the default value          |
| 15:0      | CCR2B | RW         | Compare capture register, compare with cache function |

## 15.7.19 ATIM\_CH3CCRA channel 3 compare capture register A

Address offset: 0x4C Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                  |
|-----------|-------|------------|-------------------------------------------------------|
| 31:16     | RFU   | -          | Reserved bits, please keep the default value          |
| 15:0      | CCR3A | RW         | Compare capture register, compare with cache function |



# 15.7.20 ATIM\_CH3CCRB channel 3 compare capture register B

Address offset: 0x50 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                  |
|-----------|-------|------------|-------------------------------------------------------|
| 31:16     | RFU   | -          | Reserved bits, please keep the default value          |
| 15:0      | CCR3B | RW         | Compare capture register, compare with cache function |

# 15.7.21 ATIM\_CH4CCR channel 4 compare capture register

Address offset: 0x54 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                  |
|-----------|------|------------|-------------------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value          |
| 15:0      | CCR4 | RW         | Compare capture register, compare with cache function |

# 16 Independent watchdog timer (IWDT)

## 16.1 Overview

The CW32W031 integrates an independent watchdog timer (IWDT) and uses a dedicated internal RC clock source RC10K to avoid external factors during operation. Once the IWDT is started, the user needs to reload the IWDT counter within the specified time interval, otherwise the counter overflow will trigger a reset or generate an interrupt signal. After the IWDT is started, the counting can be stopped. The IWDT can be selected to keep running or suspend counting during DeepSleep mode.

The specially set key-value register can lock the key registers of the IWDT to prevent the registers from being accidentally modified.

## 16.2 Main Features

- 12-bit down counter
- Independent internal low-speed RC oscillator
- Programmable clock prescale period
- Overflow can trigger interrupt or reset
- Register protection lock function
- Counting can be suspended in DeepSleep mode

## 16.3 Functional description

## 16.3.1 Functional block diagram

The functional block diagram of IWDT is shown in the following figure:

Key-value register IWDT\_KŘ CR.PRS RC10K 0 OV Pre-divider 12-bit down counter /4, .../512 CNT IWDT reset 1 Overloading register **IWDT** interrupt DeepSleep ARR CR.PAUSE CR.ACTION CR.IE

Figure 16-1 IWDT functional block diagram

The IWDT is implemented by a 12-bit reloadable down-counter, and its counting clock source is the internal dedicated low-speed RC oscillator RC10K. The clock source RC10K signal can be prescaled by 4 to 512 through the PRS bit field of the control register IWDT\_CR. When the IWDT counter overflows, it can optionally generate interrupt and reset signals.

#### 16.3.2 Operating modes

To start the IWDT counter, you need to write 0xCCCC to the key value register IWDT\_KR, and the counter starts to count down from 0xFFF.

Before the counter reduces to 0, writing 0xAAAA to the IWDT\_KR register will trigger a counter reload, loading the ARR register value into the counter. When the IWDT counter value is reduced to 0, an overflow event will be generated. The overflow event can trigger the MCU reset or generate the IWDT interrupt signal, and trigger the counter reload at the same time. The ACTION and IE bit fields of the control register IWDT\_CR are used to control whether interrupts and resets are generated when the watchdog overflows, as shown in the following table:

| IWDT_CR.ACTION | IWDT_CR.IE | Action after IWDT overflows |
|----------------|------------|-----------------------------|
| 0              | X          | Reset                       |
| 1              | 1          | No reset, only interrupt    |
| 1              | 0          | No reset, no interrupt      |

Table 16-1 Operating modes

When the MCU enters the DeepSleep mode, the IWDT can choose to suspend the IWDT counting, so as to achieve lower overall system power consumption: the PAUSE bit field of the control register IWDT\_CR is 0, and the IWDT timer is kept running in the DeepSleep mode; when it is 1, the counting is suspended, the IWDT automatically resumes counting when the MCU exits the DeepSleep mode.



#### 16.3.3 Window options

Write a value smaller than the reload register IWDT\_ARR to the window register IWDT\_WINR to make the IWDT work in the window watchdog mode. The default value of the IWDT\_WINR register is 0x0FFF, that is, the window option is closed by default.

Modify the value of the IWDT\_WINR register will trigger a reload operation to load the ARR register value into the counter.

When using the IWDT window function, the user should perform a reload operation before the counter value is less than or equal to the IWDT\_WINR window value and decrements to 0 to avoid reset or watchdog timer overflow. A reload operation when the watchdog counter value is greater than the window value will trigger a system reset.

## 16.3.4 Register lock function

Through the key value register IWDT\_KR of the IWDT, the important registers IWDT\_CR, IWDT\_ARR, and IWDT\_WINR of the IWDT can be configured to be locked or unlocked. The registers cannot be modified in the locked state.

Write 0x5555 to the IWDT\_KR register to unlock the IWDT\_CR, IWDT\_ARR, and IWDT\_WINR registers; write any other value to the IWDT\_KR register to enable lock protection.

After the CW32W031 is powered on, the IWDT\_CR, IWDT\_ARR, and IWDT\_WINR registers are locked by default, and the user needs to unlock them before modifying them.

#### 16.3.5 Start refresh and stop

Configure the IWDT\_KR register to start, refresh and stop the IWDT:

- Write 0xCCCC to start IWDT
- Write 0xAAAA, reload the counter, that is, refresh the IWDT
- Write 0x5A5A, 0xA5A5 sequentially, stop IWDT

#### Caution:

The above operations will simultaneously activate the IWDT register lock protection.



## 16.3.6 Status register

The status register IWDT\_SR indicates the current running status or register update status of the IWDT, as shown in the following table:

Table 16-2 IWDT status indication

| IWDT_SR bit | Name   | Description               | 1                 | 0                |
|-------------|--------|---------------------------|-------------------|------------------|
| 4           | RUN    | Run flag                  | Running           | Not running      |
| 3           | OV     | Overflow flag             | Generate overflow | Not overflow     |
| 5           | RELOAD | Counter reload flag       | Reloading         | Reload done      |
| 2           | WINRF  | WINR register update flag | Updating          | Update completed |
| 1           | ARRF   | ARR register update flag  | Updating          | Update completed |
| 0           | CRF    | CR register update flag   | Updating          | Update completed |

To ensure the correct operation of the IWDT register, after updating IWDT\_WINR, IWDT\_ARR, and IWDT\_CR, the user needs to check whether the WINRF, ARRF, and CRF flags are 0 to confirm whether the operation is completed.

To ensure the reload operation of the IWDT, the user should check whether the RELOAD flag is 0 after the reload operation.

## 16.3.7 Timing duration setting

The counting clock source of the IWDT is the dedicated low-speed clock RC10K (the clock frequency is about 10KHz, please refer to the datasheet for details). By controlling the PRS bit field of the IWDT\_CR register, the frequency of the clock source RC10K signal can be divided, as shown in the following table:

Table 16-3 IWDT prescaler divider table

| IWDT_CR.PRS | Prescaler value |
|-------------|-----------------|
| 000         | 4               |
| 001         | 8               |
| 010         | 16              |
| 011         | 32              |
| 100         | 64              |
| 101         | 128             |
| 110         | 256             |
| 111         | 512             |

Watchdog timer duration calculation formula:

$$T = (4 \times 2^{PRS} / f) \times (ARR + 1)$$

Where, f is the frequency of the clock source RC10K, PRS is the prescaler divider, and ARR is the reload value.

Therefore, when the frequency of the clock source RC10K is 10000Hz, the longest and shortest timing ranges of the IWDT are:

IWDT shortest timing = 
$$(4 \times 2^{0} / 10000) \times (0x000 + 1) \approx 400 \mu s$$
  
IWDT longest timing =  $(4 \times 2^{0} / 10000) \times (0xFFF + 1) \approx 209.7 s$ 

Example: When the frequency of the clock source RC10K is 10000Hz, set the prescale value to 64 and the reload value to 512, then:

IWDT timing duration = 
$$(4 \times 2^4 / 10000) \times (512 + 1) = 3.28 \text{ s}$$

## 16.4 Programming examples

#### 16.4.1 Configure IWDT as independent watchdog

- **Step 1:** Set SYSCTRL\_APBEN1.IWDT to 1 to enable the configuration clock of IWDT;
- Step 2: Write 0xCCCC to the IWDT\_KR register to start the IWDT;

#### Caution:

The relevant registers can be modified only after the IWDT needs to be started.

- Step 3: Write 0x5555 to the IWDT\_KR register to release the lock function of the IWDT register;
- Step 4: Configure IWDT\_CR, configure the prescale value of watchdog count clock and RC10K oscillator, action after overflow, whether to automatically suspend in DeepSleep mode;
- Step 5: Configure IWDT\_ARR and configure the overflow period of the watchdog;
- Step 6: Wait for IWDT\_SR.ARRF and IWDT\_SR.CRF to become 0, wait for the reload value and CR register update to complete;
- Step 7: Write 0xAAAA to the IWDT\_KR register to load the ARR into the IWDT counter.

## 16.4.2 Configure IWDT as window watchdog

- Step 1: Set SYSCTRL\_APBEN1.IWDT to 1 to enable the configuration clock of IWDT;
- Step 2: Write 0xCCCC to the IWDT\_KR register to start the IWDT;

#### Caution:

The relevant registers can be modified only after the IWDT needs to be started.

- Step 3: Write 0x5555 to the IWDT\_KR register to release the lock function of the IWDT register;
- Step 4: Configure IWDT\_CR, configure the prescale value of watchdog count clock and RC10K oscillator, action after overflow, whether to automatically suspend in DeepSleep mode;
- Step 5: Configure IWDT\_ARR, configure the reload value of the watchdog;
- **Step 6:** Configure IWDT\_WINR, configure the window size, Caution that IWDT\_WINR must be less than the overloaded value of IWDT\_ARR;
- Step 7: Wait for IWDT\_SR.ARRF, IWDT\_SR.WINRF and IWDT\_SR.CRF to become 0, wait for the reload value, window register and CR register update to complete;
- Step 8: Write 0xAAAA to the IWDT\_KR register to load the ARR into the IWDT counter.

#### 16.4.3 Refresh IWDT (feed dog operation)

- Step 1: Write 0xAAAA to the IWDT\_KR register to load ARR into the counter;
- Step 2: Wait for IWDT\_SR.RELOAD to become 0, and wait for the reload operation to complete.



# 16.5 List of registers

IWDT base address: IWDT\_BASE = 0x4000 3000

Table 16-4 List of IWDT registers

| Register name | Register address | Register description |
|---------------|------------------|----------------------|
| IWDT_KR       | IWDT_BASE + 0x00 | Key-value register   |
| IWDT_CR       | IWDT_BASE + 0x04 | Control register     |
| IWDT_ARR      | IWDT_BASE + 0x08 | Reload register      |
| IWDT_SR       | IWDT_BASE + 0x0C | Status register      |
| IWDT_WINR     | IWDT_BASE + 0x10 | Window register      |
| IWDT_CNT      | IWDT_BASE + 0x24 | Count value register |

# 16.6 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

## 16.6.1 IWDT\_KR key-value register

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                               |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                       |
| 15:0      | KR   | WO         | Write 0xCCCC: start the IWDT counter Write 0xCCCC: start the IWDT counter Write 0x5A5A, 0xA5A5 in sequence: stop watchdog Write 0x5555: release the write protection of IWDT_ARR, IWDT_WINR, IWDT_CR Write to non-0x5555: enable write protection of IWDT_ ARR, IWDT_WINR, IWDT_CR |

## 16.6.2 IWDT\_CR control register

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                         |
|-----------|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6      | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                 |
| 5         | PAUSE  | RW         | IWDT pause control in Deepsleep mode 0: IWDT continues to run in DeepSleep mode 1: IWDT auto-pause in DeepSleep mode                                                                                                                                                         |
| 4         | IE     | RW         | IWDT interrupt enable control 0: Watchdog interrupt disabled 1: Watchdog interrupt enabled                                                                                                                                                                                   |
| 3         | ACTION | RW         | Action configuration after IWDT overflow 0: Reset after watchdog overflow 1: Interrupt after watchdog overflow                                                                                                                                                               |
| 2:0       | PRS    | RW         | Configure the divider ratio of the watchdog count clock to the RC10K oscillator 000: 4 frequency division 001: 8 frequency division 010: 16 frequency division 011: 32 frequency division 100: 64 frequency division 101: 128 frequency division 111: 512 frequency division |

## Caution:

This register can be modified only after writing 0x5555 to the IWDT\_KR register; IWDT\_CR can only be modified when IWDT\_SR.CRF is 0.

## 16.6.3 IWDT\_ARR reload register

Address offset: 0x08 Reset value: 0x0000 0FFF

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:12     | RFU  | -          | Reserved bits, please keep the default value |
| 11:0      | ARR  | RW         | IWDT reload value                            |

## Caution:

This register can be modified only after writing 0x5555 to the IWDT\_KR register; This register can be modified only when IWDT\_SR.ARRF is 0.



# 16.6.4 IWDT\_CNT count value register

Address offset: 0x24 Reset value: 0x0000 0FFF

| Bit field | Name | Permission | Function description                                                                                                         |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:12     | RFU  | -          | Reserved bits, please keep the default value                                                                                 |
| 11:0      | CNT  | RO         | Count value register Caution: The count value can only be considered to be read if the value read twice in a row is the same |

# 16.6.5 IWDT\_WINR window register

Address offset: 0x10 Reset value: 0x0000 0FFF

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:12     | RFU  | -          | Reserved bits, please keep the default value |
| 11:0      | WINR | RW         | Window comparator compare value              |

# 16.6.6 IWDT\_SR status register

Address offset: 0x0C Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                 |
|-----------|--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6      | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                         |
| 5         | RELOAD | RO         | WDT counter reload flag 0: WDT counter has completed reload operation 1: WDT counter is reloading Caution: In window mode, you need to wait for the flag to become 0 after reloading |
| 4         | RUN    | RO         | WDT running flag 0: WDT is not running 1: WDT is running                                                                                                                             |
| 3         | OV     | RW0        | WDT overflow flag<br>R0: WDT does not overflow<br>R1: WDT overflow, write 0 to clear                                                                                                 |
| 2         | WINRF  | RO         | WINR register update flag 0: WINR register update completed 1: WINR register is updating Caution: After writing the WINR register, you need to wait for this flag to become 0        |
| 1         | ARRF   | RO         | ARR register update flag 0: ARR register update completed 1: ARR register is updating Caution: After writing the ARR register, you need to wait for this flag to become 0            |
| 0         | CRF    | RO         | CR register update flag 0: CR register update completed 1: CR register is updating Caution: After writing the CR register, you need to wait for the flag to become 0                 |

# 17 Window watchdog timer (WWDT)

## 17.1 Overview

The CW32W031 integrates a window watchdog timer (WWDT), the user needs to refresh within the set time window, otherwise it will trigger a system reset. WWDT is usually used to monitor the program execution flow with strict time requirements to prevent the abnormal execution of the application program caused by external interference or unknown conditions, resulting in system failure.

## 17.2 Main features

- 7-bit down counter
- PCLK clock driven, 8-level prescaler, maximum frequency division 524288
- Supports pre-overflow interrupt and count overflow, load count value error reset
- Can not be closed after opening, unless the system is reset

## 17.3 Functional description

#### 17.3.1 Functional block diagram

The functional block diagram of WWDT is shown in the following figure:

CR1.PRS CR1.WINR **Update WCNT PCLK** Pre-divider Window register /4096, .../ 524288 WINR WCNT>WINR WWDT reset **WWDTCLK** 7-bit downward OV counter WCNT POV WWDT interrupt CR1.IE CR0.WCNT

Figure 17-1 WWDT functional block diagram

WWDT contains a 7-bit down counter. The counting clock source is the internal system clock PCLK. The clock source PCLK can be divided by the PRS bit field of the control register WWDT\_CR1. After frequency division, the counting clock WWDTCLK is used to drive the counter to count.

The WWDT will stop counting in DeepSleep mode, and resume normal work after the CPU is woken up.

#### 17.3.2 Operating mode

After the system is reset, the window watchdog WWDT is in a closed state, and the EN bit field of the control register WWDT\_CR0 is set to 1 to start the WWDT. Once the WWDT is opened, it cannot be closed unless a reset occurs.

Before starting the WWDT, the user must preset the watchdog overflow time and window time. Setting the value of WWDT\_CR0.WCNT can update the initial value of the counter, and setting the value of WWDT\_CR1. WINR can configure the window value of the watchdog. The window value must be less than the initial value of the watchdog counter. After starting the WWDT, the counter counts down from the initial value.

When the counter decrements to 0x40, the pre-overflow signal POV will be generated, and setting WWDT\_CR1. IE to 1 will generate a pre-overflow interrupt.

When the counter decrements to 0x3F, an overflow signal OV will be generated, which can trigger a system reset.

When the current count value WCNT is greater than the window value WINR, updating the watchdog counter will also trigger a system reset.



#### 17.3.3 Refresh counter

When WWDT is running, the counter can be refreshed only when the count value is less than or equal to the window value and the count value is decremented to 0x3F, that is, the dog feeding operation, otherwise a system reset will occur.

Set the value of WWDT\_CR1.WINR to configure the upper limit of the delay time window before reset, and the lower limit of the delay time window is fixed at 0x3F. The timing of feeding dog of the window watchdog is shown in the following figure:



Figure 17-2 Refresh (feed dog) timing of the window watchdog

## 17.3.4 Dog-feeding time

The calculation formula of the dog feeding time of the window watchdog:

Minimum time for dog-feeding:

$$T_{WWDT MIN} = T_{PCLK} \times 4096 \times 2^{PRS} \times (WCNT - WINR)$$

Maximum time for dog-feeding:

$$T_{WWDT\ MAX} = T_{PCLK} \times 4096 \times 2^{PRS} \times (WCNT - 0x3F)$$

Where:

T<sub>PCLK</sub>: PCLK clock period PRS: Prescale factor

WCNT: Counter current count value WINR: Watchdog window value

#### Example:

When the PCLK frequency is 24MHz, the prescaler factor PRS is set to 0x01, WCNT is set to 0x6F, and the window value WINR is set to 0x4F, then the dog-feeding time is as follows:

$$T_{WWDT,MIN} = 1 / 24MHz \times 4096 \times 2^{1} \times (0x6F - 0x4F) \approx 10.922 \text{ ms}$$

$$T_{WWDT MAX} = 1 / 24MHz \times 4096 \times 2^{1} \times (0x6F - 0x3F) = 16.384 \text{ ms}$$

That is, the dog-feeding time cannot be earlier than 10.922ms at the earliest, otherwise an error in the loading count value will occur and the system will reset; the dog-feeding time cannot be later than 16.384ms at the latest, otherwise an underflow will occur and the system will reset. The time window size for properly dog-feeding is about 5ms.



## 17.3.5 Reset and interrupt

When the value of the counter WCNT is decremented to 0x40, the pre-overflow interrupt flag bit WWDT\_SR.POV is set by hardware. If the IE bit field of the control register WWDT\_CR1 is set to 1 (Caution: this bit cannot be cleared to 0 after being set to 1), a pre-overflow interrupt flag will be generated. Overflow interrupt request. The user can update the counter WCNT in the interrupt service routine to avoid the reset of the WWDT.

A system reset can be triggered when one of the following conditions is met:

- 1. The value of the counter WCNT is decremented to 0x3F;
- 2. When updating the counter WCNT, the current count value is greater than the window value;
- 3. Write a value less than or equal to 0x3F to WWDT\_CR0.WCNT.

## 17.4 Programming examples

## WWDT basic configuration process

- Step 1: Set SYSCTRL\_APBEN1.WWDT to 1, enable the configuration clock and working clock of WWDT;
- Step 2: Configure the prescaler of the watchdog counter clock in the window through WWDT\_CR1.PRS;
- Step 3: Configure the compare value of the window watchdog count through WWDT\_CR1.WINR;
- Step 4: Configure the initial value of the counter through WWDT\_CR0.WCNT;
- Step 5: Configure WWDT\_CR1.IE according to whether the pre-overflow interrupt needs to be enabled;
- Step 6: Set WWDT\_CR0.EN to 1 to start the window watchdog.

## WWDT dog-feeding

When the value of the counter WCNT is decremented to less than or equal to WWDT\_CR1.WINR and greater than 0x3F, rewrite the initial value of the counter to WWDT\_CR0.WCNT.



# 17.5 List of registers

WWDT base address: WWDT\_BASE = 0x4000 2C00

Table 17-1 List of WWDT registers

| Register name | Register address | Register description |
|---------------|------------------|----------------------|
| WWDT_CR0      | WWDT_BASE + 0x00 | Control register 0   |
| WWDT_CR1      | WWDT_BASE + 0x04 | Control register 1   |
| WWDT_SR       | WWDT_BASE + 0x08 | Status register      |

# 17.6 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

## 17.6.1 WWDT\_CR0 control register 0

Address offset: 0x00 Reset value: 0x0000 007F

| Bit field | Name | Permission | Function description                                                                             |
|-----------|------|------------|--------------------------------------------------------------------------------------------------|
| 31:8      | RFU  | -          | Reserved bits, please keep the default value                                                     |
| 7         | EN   | RW1        | WWDT enable control, cannot be disabled after enabling 0: WWDT disabled 1: WWDT enabled          |
| 6:0       | WCNT | RW         | Read: WWDT counter current count value Write: Update the current count value of the WWDT counter |

# 17.6.2 WWDT\_CR1 control register 1

Address offset: 0x04 Reset value: 0x0000 007F

| Bit field | Name | Permission | Function description                                                                                                                                                                                     |
|-----------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                             |
| 10        | IE   | RW         | WWDT pre-overflow interrupt enable control 0: Pre-overflow interrupt disabled 1: Pre-overflow interrupt enabled Caution: It cannot be cleared after being set to 1                                       |
| 9:7       | PRS  | RW         | WWDT count clock prescale value<br>000: PCLK / 4096<br>001: PCLK / 8192<br>010: PCLK / 16384<br>011: PCLK / 32768<br>100: PCLK / 65536<br>101: PCLK / 131072<br>110: PCLK / 262144<br>111: PCLK / 524288 |
| 6:0       | WINR | RW         | Watchdog window value                                                                                                                                                                                    |

# 17.6.3 WWDT\_SR status register

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                    |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------------------|
| 31:1      | RFU  | -          | Reserved bits, please keep the default value                                                                            |
| 0         | POV  | RW         | WWDT pre-overflow flag 0: No pre-overflow occurred in WWDT 1: WWDT pre-overflow has occurred, write 0 to clear the flag |

# 18 Universal Asynchronous Receiver/Transmitter (UART)

## 18.1 Overview

CW32W031 integrates three universal asynchronous receiver/transmitter (UART), supports asynchronous full-duplex, synchronous half-duplex and single-wire half-duplex modes, supports hardware data flow control and multi-computer communication, also supports LIN (Local Interconnect Network); programmable data frame structure can provide wide range of baud rate selection through wavelet baud rate generator. Built-in timer module supporting receive timeout detection, receive idle detection, automatic baud rate detection and general timing functions.

The UART controller works in a dual clock domain, allowing data reception in DeepSleep mode, and the reception completion interrupt can wake the MCU back to Active mode.

## 18.2 Main features

- Supports dual clock domain drive
  - Configure clock PCLK
  - Transfer clock UCLK
- Programmable data frame structure
  - Data word length: 8/9 bits, LSB first
  - Parity bit: no parity/odd parity/even parity
  - Stop bit length: 1/1.5/2 bits
- 16-bit integer, 4-bit fractional baud rate generator
- Supports asynchronous full-duplex, synchronous half-duplex, single-wire half-duplex
- Supports hardware flow control RTS, CTS
- Supports Direct Memory Access (DMA)
- Supports multi-machine communication, automatic address recognition
- 9 interrupt sources with interrupt flags
- Auto baud rate detection mode 1/2
- Receive timeout detection/idle detection
- Built-in timer module supports universal timer function
- Error detection: parity error, frame structure error
- Send and receive data in low power mode, interrupt wake-up MCU
- LIN master synchronous break send capability and LIN slave break detection capability
  - Supports length-configurable Break Field generation
  - Supports 10/11 bit Break Field detection



## 18.3 Functional description

#### 18.3.1 Functional block diagram

The UART controller is mounted on the APB bus, and the clock domain PCLK is configured, which is fixed to the APB bus clock PCLK, which is used for register configuration logic work; transfer clock domain UCLK is used for data transceiver logic work, and its source can be selected from PCLK clock, external low-speed clock clock (LSE) and internal low-speed clock (LSI). The dual clock domain design facilitates baud rate setting and supports waking up the controller from DeepSleep mode.

The functional block diagram of the UART controller is shown in the following figure:



Figure 18-1 UART functional block diagram

The UART controller supports multiple operating modes. In different operating modes, each pin has different function and different pin configuration, as shown in the following table (where x = 1, 2, 3):



Table 18-1 UART ports configuration

| Operating mode                        | UART pins              | Function                        | GPIO configuration                                                  |
|---------------------------------------|------------------------|---------------------------------|---------------------------------------------------------------------|
|                                       | UARTx_TXD              | Data serial output              | Digital, push-pull output/open-drain output, multiplexed            |
| Asynchronous full duplex              | UARTx_RXD              | Data serial input               | Digital, pull-up input, multiplexed                                 |
| Asynchronous full duplex              | UARTx_RTS <sup>1</sup> | Request to send                 | Digital, push-pull output/open-drain output, multiplexed            |
|                                       | UARTx_CTS <sup>1</sup> | Allow to send                   | Digital, pull-up input, multiplexed                                 |
| Consideration and the desired and the | UARTx_TXD              | Clock signal output             | Digital, push-pull output/open-drain output, multiplexed            |
| Synchronous half duplex               | UARTx_RXD              | Data transmitting and receiving | Digital, push-pull output/open-drain output, multiplexed            |
| Single-wire half duplex               | UARTx_TXD              | Data transmitting and receiving | Digital, open-drain output, multiplexed (external pull-up required) |
|                                       | UARTx_RXD              | Do not use                      | Can be used as general IO                                           |

## Caution 1:

Configuration is only required in hardware data flow control mode.

#### 18.3.2 Synchronous mode

The UART supports the synchronous half-duplex working mode. In this mode, the UARTx\_TXD pin outputs a synchronous shift clock signal, and the UARTx\_RXD pin transmits and receives data. See *Table 18-1 UART ports configuration* for the specific configuration of the UARTx\_TXD and UARTx\_RXD pins.

The synchronous mode of the UART can communicate with the single-wire half-duplex mode of the SPI. At this time, the SPI must be configured in a fixed level mode: the clock polarity CPOL is 1, and the clock phase CPHA is 1.

Set the SYNC bit field of the control register UARTx\_CR1 to 1 to make the UART work in synchronous half-duplex mode. At this time, the UART can only be used as a host, the data word length can only be 8 bits, and UARTx\_CR2.SIGNAL and UARTx\_CR2.ADDREN must be cleared.

#### 18.3.2.1 Baud rate setting

In synchronous half-duplex mode, the baud rate calculation formula:

BaudRate = UCLK / 12

Where, UCLK is the transmission clock of the UART, and its source can be PCLK, LSE or LSI, which is selected by the SOURCE bit field of the control register UARTx\_CR2.

#### 18.3.2.2 Data transmission and reception

Set the UART transmitting enable bit UARTx\_CR1.TXEN to 1 to make the UART work in the transmitting state. After writing the data to the UARTx\_TDR register, the data will be serially output from the UARTx\_RXD pin, and the UARTx\_TXD pin will output a synchronous shift clock signal. When the data transmission is completed, the transmission completion interrupt flag UARTx\_ISR.TC will be set by hardware.

Figure 18-2 Transmit timing in synchronous half-duplex mode (transmit two bytes of data)



Set the UART receiving enable bit UARTx\_CR1.RXEN to 1 to make the UART work in the receiving state, the UARTx\_TXD pin will output a synchronous shift clock signal, and the data will be serially input from the UARTx\_RXD pin. After the data reception is completed, the reception completion interrupt flag UARTx\_ISR.RC will be set by hardware, and the UARTx\_RDR register can be read at this time. Before receiving the next byte, the UARTx\_ISR.RC flag must be cleared to 0. After the RC flag is cleared, the next byte of data will be received immediately.

Figure 18-3 Receive timing in synchronous half-duplex mode (receive two bytes of data)



351 / 572

#### 18.3.3 Asynchronous mode

#### 18.3.3.1 Data frame format

In UART asynchronous communication, data is transmited and received in the form of data frames, and a frame of data includes a start bit, a data field, an optional parity bit and a stop bit with a programmable width.

#### Start bit

The length of the start bit is fixed at 1 bit, and the judgment method of the start bit can be selected by falling edge or low level, which is selected by the START bit field of the control register UARTx\_CR1. Generally, the falling edge is selected as the judgment method of the start bit. The low-level method to determine the start bit is mainly used in the low-power mode. Please refer to section 18.4 Low power mode.

#### Data field

The data word length can be set to 8 bits or 9 bits, and is automatically configured by the presence or absence of parity bits. When set to no parity, the data word length is 8 bits, and when it is set to have parity (including custom parity, even parity, odd parity), the data word length is automatically set to 9 bits. Please refer to *Table 18-2 Data frame structure*.

#### Parity bit

The parity mode supports custom parity, even parity and odd parity, which is selected by the PARITY bit field of the control register UARTx\_CR1.

Custom parity: The parity bit is determined by software writing to UARTx\_TDR[8] and reading UARTx\_RDR[8]. It is mainly used in multi-computer communication. Please refer to section 18.3.3.6 Multi-machine communicatio.

Odd parity: The parity bit makes the total number of "1"s in the data bits and parity bits in a frame of data an odd number.

Even parity: The parity bit makes the total number of "1" in the data bits and the parity bit in a frame of data an even number.

UARTx\_CR1.PARITY is used to set the parity mode, and the corresponding relationship with the data frame is shown in the following table:

| UARTx_CR1.PARITY | Checkout mode                               | Data frame                                            |
|------------------|---------------------------------------------|-------------------------------------------------------|
| 00               | No parity Start bit + 8-bit data + stop bit |                                                       |
| 01               | Custom parity                               | Start bit + 8-bit data + custom parity bit + stop bit |
| 10               | Even parity                                 | Start bit + 8-bit data + even parity bit + stop bit   |
| 11               | Odd parity                                  | Start bit + 8-bit data + odd parity bit + stop bit    |

Table 18-2 Data frame structure

#### Stop bit

The length of the stop bit can be configured as 1, 1.5 or 2 bits, which is configured through the STOP bit field of the control register UARTx\_CR1.



#### 18.3.3.2 Fractional baud rate generator

#### Generation of baud rate

The receive and transmit baud rates of the UART are the same, generated by the same baud rate generator.

The baud rate generator supports 4 sampling modes: 16 times sampling, 8 times sampling, 4 times sampling and dedicated sampling. The specific sampling mode is selected by the OVER bit field of the control register UARTx CR1.

1. OVER = 00, set 16 times sampling, baud rate calculation formula:

BaudRate = 
$$UCLK / (16 \times BRRI + BRRF)$$

UCLK is the transmission clock of UART, and its source can be PCLK, LSE or LSI. The specific source is selected by UARTx\_CR2.SOURCE.

BRRI (UARTx\_BRRI [15:0] ) is the integer part of the baud rate counter and can be set in the range of  $1 \sim 65535$ .

BRRF (UARTx\_BRRF [3:0] ) is the fractional part of the baud rate counter, and the settable range is  $0 \sim 15$ .

#### Example 1:

When the frequency of the transmission clock UCLK is 24MHz, set BRRI=156 (ie UARTx\_BRRI=0x9C), BRRF=4 (ie UARTx\_BRRF=0x04), then:

BaudRate = 
$$24000000 / (16 \times 156 + 4) = 9600$$
 bps

## Example 2:

When the frequency of the transmission clock UCLK is 24MHz, it is required to configure BaudRate=115200bps, and calculate

then:

BRRI = 208.33 / 16 = 13.02, the nearest integer is: 13 (0x0D)

BRRF =  $0.02 \times 16 = 0.32$ , the nearest integer is: 0 (0x00)

That is, you need to set UARTx\_BRRI to 0x0D and UARTx\_BRRF to 0x00

At this time, the actual baud rate BaudRate=115384.62bps, the error rate is 0.16%

2. OVER = 01, set 8 times sampling, baud rate calculation formula:

BaudRate = 
$$UCLK / (8 \times BRRI)$$

3. OVER = 10, set 4 times sampling, baud rate calculation formula:

BaudRate = 
$$UCLK / (4 \times BRRI)$$

4. OVER = 11, set dedicated sampling, baud rate calculation formula:

BaudRate = 
$$(256 \times UCLK) / BRRI$$

#### Caution:

Dedicated sampling is only suitable for UART communication at 2400bps, 4800bps or 9600bps baud rate when the transmission clock source is LSE or LSI.



## Example 1:

The transmission clock UCLK selects LSE, the frequency is 32.768KHz, and the baud rate of 9600bps is required to be configured, then:

BRRI =  $256 \times 32768 / 9600 = 873.81$ , the nearest integer is: 874 (0x36A)

That is, you need to set UARTx\_BRRI to 0x36A

At this time, the actual baud rate BaudRate=9597.95bps, the error is 0.02%

## Example of baud rate setting

Table 18-3 to Table 18-9 list the setting value of the baud rate count register and the baud rate error when the frequency of the common MCU is used.

Table 18-3 UCLK is 4MHz baud rate setting example (OVER=00)

| Baud rate (bps) | BRRI | BRRF | Actual baud rate | Error rate |
|-----------------|------|------|------------------|------------|
| 4800            | 52   | 1    | 4801.92          | 0.04%      |
| 9600            | 26   | 1    | 9592.33          | -0.08%     |
| 14400           | 17   | 6    | 14388.49         | -0.08%     |
| 19200           | 13   | 0    | 19230.77         | 0.16%      |
| 38400           | 6    | 8    | 38461.54         | 0.16%      |
| 56000           | 4    | 7    | 56338.03         | 0.60%      |
| 57600           | 4    | 5    | 57971.01         | 0.64%      |
| 115200          | 2    | 3    | 114285.71        | -0.79%     |
| 256000          | 1    | 0    | 250000           | -2.34%     |

Table 18-4 UCLK is 8MHz baud rate setting example (OVER=00)

| Baud rate (bps) | BRRI | BRRF | Actual baud rate | Error rate |
|-----------------|------|------|------------------|------------|
| 4800            | 104  | 3    | 4799.04          | -0.02%     |
| 9600            | 52   | 1    | 9603.84          | 0.04%      |
| 14400           | 34   | 12   | 14388.49         | -0.08%     |
| 19200           | 26   | 1    | 19184.65         | -0.08%     |
| 38400           | 13   | 0    | 38461.54         | 0.16%      |
| 56000           | 8    | 15   | 55944.06         | -0.10%     |
| 57600           | 8    | 11   | 57553.96         | -0.08%     |
| 115200          | 4    | 5    | 115942.03        | 0.64%      |
| 500000          | 1    | 0    | 500000           | 0.00%      |

Table 18-5 UCLK is 16MHz baud rate setting example (OVER=00)

| Baud rate (bps) | BRRI | BRRF | Actual baud rate | Error rate |
|-----------------|------|------|------------------|------------|
| 4800            | 208  | 5    | 4800.48          | 0.01%      |
| 9600            | 104  | 3    | 9598.08          | -0.02%     |
| 14400           | 69   | 7    | 14401.44         | 0.01%      |
| 19200           | 52   | 1    | 19207.68         | 0.04%      |
| 38400           | 26   | 1    | 38369.30         | -0.08%     |
| 56000           | 17   | 14   | 55944.06         | -0.10%     |
| 57600           | 17   | 6    | 57553.96         | -0.08%     |
| 115200          | 8    | 11   | 115107.91        | -0.08%     |
| 1000000         | 1    | 0    | 1000000          | 0.00%      |

# Table 18-6 UCLK is 24MHz baud rate setting example (OVER=00)

| Baud rate (bps) | BRRI | BRRF | Actual baud rate | Error rate |
|-----------------|------|------|------------------|------------|
| 4800            | 312  | 8    | 4800.00          | 0.00%      |
| 9600            | 156  | 4    | 9600.00          | 0.00%      |
| 14400           | 104  | 3    | 14397.12         | -0.02%     |
| 19200           | 78   | 2    | 19200.00         | 0.00%      |
| 38400           | 39   | 1    | 38400.00         | 0.00%      |
| 56000           | 26   | 13   | 55944.06         | -0.10%     |
| 57600           | 26   | 1    | 57553.96         | -0.08%     |
| 115200          | 13   | 0    | 115384.62        | 0.16%      |
| 1500000         | 1    | 0    | 1500000          | 0.00%      |

Table 18-7 UCLK is 32MHz baud rate setting example (OVER=00)

| Baud rate (bps) | BRRI | BRRF | Actual baud rate | Error rate |
|-----------------|------|------|------------------|------------|
| 4800            | 416  | 11   | 4799.76          | 0.00%      |
| 9600            | 208  | 5    | 9600.96          | 0.01%      |
| 14400           | 138  | 14   | 14401.44         | 0.01%      |
| 19200           | 104  | 3    | 19196.16         | -0.02%     |
| 38400           | 52   | 1    | 38415.37         | 0.04%      |
| 56000           | 35   | 11   | 56042.03         | 0.08%      |
| 57600           | 34   | 12   | 57553.96         | -0.08%     |
| 115200          | 17   | 6    | 115107.91        | -0.08%     |
| 2000000         | 1    | 0    | 2000000          | 0.00%      |

# Table 18-8 UCLK is 48MHz baud rate setting example (OVER=00)

| Baud rate (bps) | BRRI | BRRF | Actual baud rate | Error rate |
|-----------------|------|------|------------------|------------|
| 4800            | 625  | 0    | 4800.00          | 0.00%      |
| 9600            | 312  | 8    | 9600.00          | 0.00%      |
| 14400           | 208  | 5    | 14401.44         | 0.01%      |
| 19200           | 156  | 4    | 19200.00         | 0.00%      |
| 38400           | 78   | 2    | 38400.00         | 0.00%      |
| 56000           | 53   | 9    | 56009.33         | 0.02%      |
| 57600           | 52   | 1    | 57623.05         | 0.04%      |
| 115200          | 26   | 1    | 115107.91        | -0.08%     |
| 3000000         | 1    | 0    | 3000000          | 0.00%      |

# Table 18-9 UCLK is 32.768KHz baud rate setting example (OVER=11)

| Baud rate (bps) | BRRI | Actual baud rate | Error rate |
|-----------------|------|------------------|------------|
| 2400            | 3495 | 2400.17          | 0.01%      |
| 4800            | 1748 | 4798.97          | -0.02%     |
| 9600            | 874  | 9597.95          | -0.02%     |

#### 18.3.3.3 Transmit control

#### Data transmission

Set UARTx\_CR1.TXEN to 1 to enable transmit circuit. After writing the data to the UARTx\_TDR register, the data will be transferred to the transmission shift register by hardware, and the transmission shift register will serially shift the data out from the lowest bit. For the register configuration of the specific transmission process, please refer to section 18.7 Programming examples.

## Transmit interrupt

In the transmission control link, there are three flag bits UARTx\_ISR.TXE, UARTx\_ISR.TC and UARTx\_ISR.TXBUSY, among which UARTx\_ISR.TXE and UARTx\_ISR.TC can generate interrupt requests.

When the data is transferred to the transmission shift register by hardware, the transmit buffer empty interrupt flag UARTx\_ISR.TXE will be set by hardware, indicating that the UARTx\_TDR register is empty, and new data to be sent is allowed to be written to the UARTx\_TDR register. While writing data to the UARTx\_TDR register, the UARTx\_ISR.TXE flag will be automatically cleared. If there is still untransmitted data in the transmission shift register at this time, the newly written data will be temporarily stored in the UARTx\_TDR register. After the current data transmission is completed, the data in the UARTx\_TDR register will be transferred by hardware to the transmission shift register. continue to transmit in the register.

When the transmission of the data frame in the transmission shift register is completed, the transmission completion interrupt flag bit UARTx\_ISR.TC will be set by hardware, indicating that a frame of data has been transmitted.

When the data frame in the transmission shift register is transmitted, if there is no data to be transmitted in the UARTx\_TDR register (ie UARTx\_ISR.TXE=1), the UART transmit busy flag UARTx\_ISR.TXBUSY will be cleared by hardware, indicating that the data in the UARTx\_TDR register and the transmission shift register has been transmitted.

In user applications, before closing the UART, it is recommended to check whether the UARTx\_ISR.TXBUSY flag has been cleared to ensure that all data has been transmitted to avoid data loss.

The UARTx\_ISR.TXE flag bit and the UARTx\_ISR.TC flag bit are generated by hardware, and both can generate interrupt requests, which are controlled by the interrupt enable bits UARTx\_IER.TXE and UARTx\_IER.TC respectively.

In the UART interrupt service routine, the interrupt source is determined by reading the UARTx\_ISR.TXE and UARTx\_ISR.TC flag bits. The corresponding flag bits should be cleared before exiting the interrupt service routine to avoid repeated entry into the interrupt service routine.

The timing diagram of the UART transmission control link is shown in the following figure:

Figure 18-4 Transmit control sequence in asynchronous working mode (transmitting two bytes of data)





357 / 572 Rev 1.0

#### 18.3.3.4 Receive control

#### Data reception

Set UARTx\_CR1.RXEN to 1 to enable the receive circuit. When the receiver detects the first falling edge of the start bit, the hardware will sample the port at 16 times the set baud rate, and at the same time, it will make a comprehensive judgement on the intermediate three sampling results of each bit, and finally form the receive data, which will be shifted into the receive shift register serially, and transferred to the UARTx\_RDR register in parallel, and at this time, the data can be be read out. For the register configuration of the specific receiving process, please refer to 18.7 Programming examples.

#### Receive interrupt

In the receiving control link, there are three flag bits UARTx\_ISR.RC, UARTx\_ISR.PE and UARTx\_ISR.FE, and all can generate interrupt requests.

When the received data is transferred from the shift register to the UARTx\_RDR register, the reception completion interrupt flag bit UARTx\_ISR.RC will be set by hardware, indicating that the reception of a frame of data has been completed. In the user program, once the UARTx\_ISR.RC flag is detected as 1, the UARTx\_RDR register should be read as soon as possible, and the UARTx\_ISR.RC flag should be cleared. If the UARTx\_RDR register is not read in time, the newly received data will overwrite the data in the UARTx\_RDR register, resulting in data loss.

When a data frame is received, the parity check will be performed automatically. If a parity check error is detected, the UARTx\_ISR.PE flag will be set by hardware, indicating a parity check error.

When receiving a data frame, if the correct stop bit is not recognized within the expected time, it is determined that a frame structure error has occurred, and the UARTx\_ISR.FE flag will be set by hardware.

The UARTx\_ISR.RC, UARTx\_ISR.PE and UARTx\_ISR.FE flag bits are generated by hardware and can generate interrupt requests, which are controlled by the interrupt enable bits UARTx\_IER.RC, UARTx\_IER.PE and UARTx\_IER.FE respectively.

In the UART interrupt service routine, the interrupt source is determined by reading the UARTx\_ISR.RC, UARTx\_ISR.PE and UARTx\_ISR.FE flag bits, and the corresponding flag bits should be cleared before exiting the interrupt service routine to avoid repeatedly entering the interrupt service routine.

In user applications, before closing the UART, it is recommended to check whether the UARTx\_ISR.RC flag has been set to 1 to ensure that all data has been received to avoid data loss.

The timing diagram of the UART receiving control link is shown in the following figure:

Figure 18-5 Receive control timing in asynchronous working mode (receive two bytes of data)





358 / 572 Rev 1.0

## 18.3.3.5 Single-wire half-duplex mode

Set UARTx\_CR2.SIGNAL to 1 to make the UART work in single-wire half-duplex mode. In this mode, the UARTx\_TXD pin is used for data transmission and reception without occupying the UARTx\_RXD pin (UARTx\_RXD can be used as general IO). See *Table 18-1 UART ports configuration* for configuration.

After writing data to the UARTx\_TDR register, the UARTx\_TXD pin immediately enters the transmit state and the output UARTx\_TDR data in the register. After the data transmission is complete, the UARTx\_TXD pin returns to its normal receive state.

When no data is sent, the UARTx\_TXD pin is in the receiving state. After the data is received, the reception completion flag UARTx\_ISR.RC will be set by hardware. At this time, the UARTx\_RDR register should be read as soon as possible, and the UARTx\_ISR.RC flag should be cleared.

#### Caution:

Users should take appropriate application layer protection mechanisms to ensure that multiple masters do not send data to the bus at the same time.

#### 18.3.3.6 Multi-machine communicatio

UART supports multi-machine communication mode. In this mode, there is one master and multiple slaves on the UART bus. Each slave has a unique slave address. During communication, the master will first send an address frame to address the slave. Only the slave with the matching address is activated and receives the data frame sent by the subsequent master.

#### Master transmits

In the multi-machine communication mode, the master needs to set UARTx\_CR1.PARITY to 1, configure it as a custom check, and the frame data length is automatically set to 9 bits.

The highest bit of the UARTx\_TDR register determines whether the master sends an address frame or a data frame. When UARTx\_TDR[8] is 1, it means that the master sends an address frame. When UARTx\_TDR[8] is 0, it means that the master sends a data frame.

#### Slave receives

In the multi-machine communication mode, the slave needs to set UARTx\_CR1.PARITY to 1, configure it as a custom check, and set UARTx\_CR2.ADDREN to 1 to enable the slave address recognition, and the slave hardware automatically detects the address sent by the host and the local machine. whether the address matches.

If the address matches, the slave will save the received address frame into the UARTx\_RDR register, the UARTx\_ISR.RC flag is set by hardware, and the UARTx\_ISR.MATCH flag is set by hardware, and the slave receives the subsequent data frame sent by the master. During the communication process, the slave should pay attention to:

- 1. The application program queries UARTx\_RDR[8] in the reception completion interrupt RC to determine whether it is an address frame or a data frame.
- 2. When the slave sends a data frame, it needs to set UARTx\_TDR[8] to 0 to avoid being regarded as an address frame by other slaves.

If the addresses do not match, the slave will not receive the data frame sent by the master, nor will it generate a reception completion interrupt, and the set UARTx\_ISR.MATCH flag will be cleared.



#### Slave address and address mask

The slave address is configured by the UARTx\_ADDR register, and the slave address should be configured to be unique. The UARTx\_MASK register is an address mask. The slave address bit corresponding to the bit '1' in UARTx\_MASK[7:0] participates in the slave address matching operation, and the slave address bit corresponding to the bit '0' does not participate in the slave address matching operation.

When all bits in UARTx\_MASK[7:0] are set to '1', that is, write 0xFF to the UARTx\_MASK register, then all 8-bit address bits of the slave address participate in the slave address matching, and the master can uniquely identify the slave.

When some bits in UARTx\_MASK[7:0] are set to '0', the corresponding slave address bits do not participate in slave address matching, so as to realize that multiple slaves respond to the same address frame sent by the master, that is, the master addresses multiple slaves at the same time.

#### Example 1:

Set the slave A: UARTx\_ADDR = 0xA0, UARTx\_MASK = 0xFE Set the slave B: UARTx\_ADDR = 0xA1, UARTx\_MASK = 0xFE Set the slave C: UARTx\_ADDR = 0xA2, UARTx\_MASK = 0xFC Set the slave D: UARTx\_ADDR = 0xA3, UARTx\_MASK = 0xFC Set the slave E: UARTx\_ADDR = 0xA5, UARTx\_MASK = 0xFF

When the master transmits a 0xA0 or 0xA1 address frame, it can address slave A, slave B, slave C, and slave D

When the master transmits 0xA2 or 0xA3 address frame, it can address slave C, slave D

When the master transmits a 0xA4 address frame, no slave is addressed

When the master transmits a 0xA5 address frame, it can address the slave E

#### Broadcast address

In multi-machine communication, the address 0xFF is defined as the broadcast address. When the master transmits the broadcast address frame, the slaves of all addresses are addressed.



#### 18.3.3.7 Hardware flow control

CW32W031 supports UART hardware flow control mode, that is, it supports request to transmit RTS and allow to transmit CTS, which is used to automatically control the transmission and reception of data.

In the data communication system, the schematic diagram of the communication hardware flow control between the data terminal equipment DTE and the data circuit terminating equipment DCE is shown in the following figure.

DTE DCE RXD TXD Transmit Reception CTS RTS control control **RXD** TXD Reception Transmit CTS RTS control control

Figure 18-6 Schematic diagram of hardware flow control

### Request to transmit RTS

Set UARTx\_CR2.RTSEN to 1 to enable RTS flow control, RTS means request to transmit, and low level is active.

When the receiver is ready to receive new data (ie UARTx\_ISR.RC=0), the RTS pin will output a low level, requesting the transmitting terminal to transmit a frame of data.

When the receiving terminal receives a frame of data (ie UARTx\_ISR.RC=1), the RTS pin will output a high level to notify the transmitting terminal to suspend transmitting.

In the user application, after reading the data in the UARTx\_RDR register, if you want to continue to receive the next frame of data, the software must clear the UARTx\_ISR.RC flag bit. At this time, the RTS pin will output a low level, requesting the transmitting terminal to transmit the next frame of data.



Figure 18-7 RTS flow control sequence

361 / 572 Rev 1.0

## Allow transmitting CTS

Set UARTx\_CR.CTSEN to 1 to enable CTS flow control, CTS means transmission is allowed, and low level is active.

When the transmitting terminal detects that the CTS signal is low, if there is data to be sent (ie UARTx\_ISR. TXE=0), and there is no data currently being transmitted, this frame of data will be transmitted.

When the transmitting terminal detects that the CTS signal is at a high level, if there is ongoing data transmission, the current transmission will continue, and the transmission will be stopped after the current transmission is completed.

In the CTS flow control process, the CTS signal level flag bit UARTx\_ISR.CTSLV indicates the current level state of the CTS pin; the CTS signal change flag bit UARTx\_ISR.CTS indicates whether the CTS signal has changed, when the CTS signal changes, The UARTx\_ISR.CTS flag will be set by hardware. When the CTS interrupt is enabled (that is, set UARTx\_IER.CTS to 1), an interrupt will be generated. Write UARTx\_ICR.CTS to 0 to clear the interrupt flag.



Figure 18-8 CTS flow control sequence

#### 18.3.4 LIN Mode

The LIN mode is selected by setting the LIN bit field in the UARTx\_CR1 register to 1. In LIN mode, the following bits must be cleared to zero.

- The SYNC, STOP and PARITY bits in the UARTx\_CR1 register
- The SIGNAL bit in the UARTx\_CR2 register

A frame of LIN data contains two parts: Header and Response. The host task is responsible for sending the frame header, and the slave task receives the frame header and parses the information contained in the frame header, and reacts to the frame header (receive/send/ignore the response part). The frame structure of LIN is shown in the following figure:

≥13bit Data1 ... Datai (i≤8)

Break Field Sync Byte Field Protected Identifier Field Data Field Checksum Field

Header Response

Figure 18-9 Structure of the LIN frame

In a LIN frame, except for the Break Field, all other segments are transmitted in the format of a byte field. The byte field includes 1 start bit, 8 data bits, and 1 stop bit, and the data transmission is preceded by the least significant bit (LSB).

#### 18.3.4.1 LIN send

#### Send Break Field

The Break Field represents the beginning of a frame of data. The number of bits in the Break Field is set by the UARTx\_TDR register. Note that the Break Field is a dominant level that lasts at least 13 bits (subject to the bit rate of the host node).

In LIN mode, set UARTx\_CR1.TXBRK to 1, and then write the number of bits of the Break Field to the UARTx\_ TDR register, and the Break Field will be sent immediately. After the Break Field is sent, the TXBRK bit is automatically cleared by the hardware.

#### Send Sync Byte Field

Writing 0x55 to the UARTx\_TDR register will send the Sync Byte Field.

#### Send Protected Identifier Field

The first 6 bits of the Protected ID segment are the frame ID, plus two parity bits called the Protected ID.

According to the parity formula, the parity bits corresponding to the frame ID are calculated, and then the protected ID is written to the data register UARTx\_TDR, which will send the protected ID segment.



#### 18.3.4.2 LIN receive

#### Detection of the Break Field

Enabling LIN mode activates the Break Field detection circuit. The length threshold of the receive Break Field is set via the BRKL bit field of the control register UARTx\_CR1.

After enabling the receive circuit, the hardware starts monitoring the start signal on the RXD pin input. After the start bit is detected, the circuit will sample the next bits. When the low width of the RXD communication line is detected to be greater than or equal to the Break Field length threshold set in the BRKL bit field and followed by the break delimiter, the UARTx\_ISR.RXBRK flag bit will be set by the hardware, indicating that the Break Field reception is complete. If UARTx\_IER.RXBRK is 1, an interrupt request will be generated.

If a high level has been sampled before the set Break Field length threshold, the detection circuitry will cancel the current detection and searches for the start bit again.

In LIN mode, when a frame structure error occurs, the receiver stops immediately until the detection circuit receives a "1" (Break Field incomplete) or receives a spacer (Break Field detected).

During Break Field detection, the frame structure error flag bit UARTx\_ISR.FE is set in hardware. While clearing the UARTx\_ISR.RXBRK flag bit, the UARTx\_ISR.FE flag needs to be cleared and the UARTx\_RDR register needs to be read to confirm that the data received is 0x00.

### Detection of the Sync Byte Field

The slave node calculates the host node bit rate by receiving the Sync Byte Field from the host node, and readjusts its own bit rate according to the calculation result. The slave node should set the TIMCR bit field of the control register UARTx\_CR2 to 0x6, configure it for automatic baud rate detection mode 2 and measure the frequency of the Sync Byte Field by counting the clock UCLK. The bit rate calculation formula is as follows:

1 bit time = (TIMCNT+(TIMARR+1) × ARR overflow times)/(8 × UCLK)

If the UART is set to 16 times sampling (OVER=00), the adjusted baud rate counter value will be as follows:

BRRI = (uint16\_t) ((TIMCNT+(TIMARR+1)  $\times$  ARR overflow times/8)  $\gg$  4)

BRRF = (uint16\_t) ((TIMCNT+(TIMARR+1)  $\times$  ARR overflow times/8)& 0x0F)



#### 18.3.5 Timer operating mode

The UART has a built-in timer module containing a 24bit up counter TIMCNT and a 24bit auto reload register TIMARR. The timer supports five operating modes as shown in the following table:

Table 18-10 Timer operating modes

| UARTx_CR2. TIMCR | Operating mode                     |
|------------------|------------------------------------|
| 010              | Waiting for timeout detection mode |
| 011              | Receive idle detection mode        |
| 101              | Auto baud rate detection mode 1    |
| 110              | Auto baud rate detection mode 2    |
| 111              | General purpose timer mode         |

### 18.3.5.1 Waiting for timeout detection mode

Set the TIMCR bit field of control register UARTx\_CR2 to 0x2, and the timer operates in wait timeout detection mode with a timeout time:

$$(TIMARR+1)/f_{BaudRate}$$

Setting UARTx\_CR2.TIMCR to 0x2 will immediately start the counter TIMCNT counting up from 0. The counting clock is the baud rate clock, and re-counts from 0 at every stop bit received; When the count reaches the reload value TIMARR the timer overflows, and at the same time the timer overflow flag bit UARTx\_ISR.TIMOV is set by hardware, indicating that the receive wait timeout is reached and the timer stops automatically; If the timer overflow interrupt is enabled (set UARTx\_IER.TIMOV to 1), the corresponding interrupt service routine will be executed, and the corresponding flag bit should be cleared before exiting the interrupt service routine to avoid entering the interrupt service routine repeatedly.

#### 18.3.5.2 Receive idle detection mode

Set the TIMCR bit field of control register UARTx\_CR2 to 0x3, and the timer operates in receive idle detection mode, with a detection idle time:

$$(TIMARR+1)/f_{BaudRate}$$

Whenever a stop bit is received, the counter TIMCNT is driven by the baud rate clock to count up from 0; When the count reaches the reloaded value TIMARR the timer overflows, and at the same time the timer overflow flag bit UARTx\_ISR.TIMOV is set by the hardware, indicating that the receive idle timeout is reached, and the timer stops automatically; If the timer overflow interrupt is enabled (set UARTx\_IER.TIMOV to 1), the corresponding interrupt service routine will be executed, and the corresponding flag bit should be cleared before exiting the interrupt service routine to avoid entering the interrupt service routine repeatedly.



#### 18.3.5.3 Auto baud rate detection mode

The UART supports two auto baud rate detection modes. Set the TIMCR bit field of control register UARTx\_CR2 to 0x5 to configure auto baud rate detection mode 1; set the TIMCR bit field of control register UARTx\_CR2 to 0x6 to configure auto baud rate detection mode 2.

#### Auto baud rate detection mode 1

The falling edge of UARTx\_RXD pin triggers the timer to start, the counter TIMCNT is driven by the counting clock UCLK to count up from 0, the timer overflows after counting to the reload value TIMARR, at the same time the timer overflow flag bit UARTx\_ISR.TIMOV is set by hardware, the counter starts counting from 0 again. The rising edge of the UARTx\_RXD pin stops the timer counting while the UARTx\_ISR.BAUD flag bit will be set by hardware, indicating that the auto baud rate detection has been completed.

#### Auto baud rate detection mode 2

Auto baud rate detection mode 2 is mainly used for clock synchronization in LIN mode, please refer to 18.3.4 LIN Mode.

The falling edge of the UARTx\_RXD pin triggers the timer to start, the counter TIMCNT is driven by the counting clock UCLK to count up from 0, the timer overflows after counting to the reload value TIMARR, at the same time the timer overflow flag bit UARTx\_ISR.TIMOV is set by hardware and the counter starts counting again from 0. The 4th falling edge of the UARTx\_RXD pin stops the timer counting, while the UARTx\_ISR.BAUD flag bit will be set by hardware, indicating that the automatic baud rate detection has been completed.

# 18.3.5.4 General purpose timer mode

The timer module built into the UART can be used as a general purpose timer, contains a 24bit up counter and is driven by the count clock UCLK.

Setting the TIMCR bit field of control register UARTx\_CR2 to 0x7 will start the timer immediately and the counter TIMCNT will accumulate counts driven by the count clock UCLK. The timer will stop automatically after a timeout (TIMARR+2) of the UCLK clock.

# 18.4 Low power mode

The UART controller works in a dual clock domain, supports normal data transmission and reception in DeepSleep mode, and wakes up the MCU back to Active mode through a reception completion interrupt.

If the source of the transmission clock UCLK is set as the low-speed clock, when the system enters the DeepSleep mode, the high-speed clock will stop, the low-speed clock will keep running, and the UART can still transmit and receive data normally (the baud rate only supports 2400bps, 4800bps and 9600bps).

To use the UART wake-up function in DeepSleep mode, you need to enable the UART reception completion interrupt (that is, set UARTx\_IER.RC to 1) before entering DeepSleep mode. When data reception is completed, the reception completion interrupt will wake up the MCU and return to Active mode.

If the source of the transmission clock UCLK is set as the high-speed clock, when the system enters the DeepSleep mode, the high-speed clock will stop running and the UART will not receive data. At this time, the MCU can still be woken up through the GPIO interrupt to receive data in DeepSleep mode. The reference configuration steps are as follows:

- Step 1: Enable the GPIO falling edge interrupt of the corresponding pin of UARTx\_RXD;
- Step 2: Set UARTx\_CR1.START to 1, and select the RXD signal start bit determination method to be low level;
- Step 3: Enable UART reception (that is, set UARTx\_CR1.RXEN to 1);
- Step 4: Enter DeepSleep mode;
- Step 5: Wait for the master to transmit data, generate a GPIO falling edge interrupt, and wake up the MCU;
- **Step 6:** Closed the GPIO interrupt function of the corresponding pin to RXD and wait for the completion of RXD reception.

For more information on the optimized design of low power mode entry and wake-up, please refer to chapter *3 Power Control (PWR) and Power Consumption*.



# 18.5 UART interrupts

The UART controller supports 9 interrupt sources. When the UART interrupt trigger event occurs, the interrupt flag bit will be set by hardware. If the corresponding interrupt enable control bit is set, an interrupt request will be generated.

A UART module of CW32W031 uses a same system UART interrupt. Whether the UART interrupt generates interrupt jump is controlled by the corresponding bit of the interrupt enable setting register NVIC\_ISER of the Nested Vectored Interrupt Controller (NVIC).

The schematic diagram of the system UART interrupt is shown in the following figure:



Figure 18-10 Schematic diagram of UART interrupt structure

In the user's UART interrupt service routine, the relevant UART interrupt flag bit should be queried for corresponding processing. Before exiting the interrupt service routine, the interrupt flag bit should be cleared to avoid repeatedly entering the interrupt routine.

The flag bits, interrupt enable bits, interrupt flag clear bits and clear methods of each interrupt source of the UART are shown in the following table:

Table 18-11 UART interrupt control

| Interrupt event                            | Interrupt flag bit | Interrupt enable bit | Flag clear method        |
|--------------------------------------------|--------------------|----------------------|--------------------------|
| Transmit buffer empty                      | ISR.TXE            | IER.TXE              | Write UARTx_TDR register |
| Complete transmit-ting                     | ISR.TC             | IER.TC               | Write 0 to ICR.TC        |
| Complete receiving                         | ISR.RC             | IER.RC               | Write 0 to ICR.RC        |
| Frame structure error                      | ISR.FE             | IER.FE               | Write 0 to ICR.FE        |
| Parity error                               | ISR.PE             | IER.PE               | Write 0 to ICR.PE        |
| CTS signal changes                         | ISR.CTS            | IER.CTS              | Write 0 to ICR.CTS       |
| Timer overflow                             | ISR.TIMOV          | IER.TIMOV            | Write 0 to ICR.TIMOV     |
| Automatic baud rate detection complete     | ISR.BAUD           | IER.BAUD             | Write 0 to ICR.BAUD      |
| Break Field reception complete in LIN mode | ISR.RXBRK          | IER.RXBRK            | Write 0 to ICR.RXBRK     |

# 18.6 Direct Memory Access (DMA)

The UART controller supports the DMA transfer function, allowing high-speed data transfer between the UART transceiver data registers and memory without CPU intervention. DMA requests can be triggered by software or hardware, and the DMA requests for transmitting TXD and receiving RXD are generated separately.

#### **DMA transmits**

Set UARTx\_CR2.DMATX to 1 to enable DMA transmit. When the UARTx\_TDR register is empty, the DMA will be triggered to transfer a frame of data from the specified storage area to the UARTx\_TDR register, until all the data configured in the DMA controller is transferred.

For the specific register configuration process of DMA transmission, please refer to chapter 8 *Direct memory access (DMA)* and section 18.7 *Programming examples*.

When the DMA transfer is completed, the corresponding DMA channel y transfer completion flag bit DMA\_ISR. TCy will be set by hardware. If the interrupt is enabled (that is, set DMA\_CSRy.TCIE to 1), an interrupt request will be generated.

In user application, before closing the UART, it is recommended to check whether the UARTx\_ISR.TXBUSY flag has been cleared to ensure that all data has been sent to avoid disrupting the last transmission process.

#### **DMA** receives

Set UARTx\_CR2.DMARX to 1 to enable DMA reception. When a frame of data is received (that is, the UARTx\_RDR register is not empty), the DMA will be triggered to transfer the data from the UARTx\_RDR register to the specified storage area, until all the data configured in the DMA controller is transferred.

For the specific register configuration process of DMA reception, please refer to chapter 8 *Direct memory access (DMA)* and section 18.7 *Programming examples*.

When the DMA transfer is completed, the corresponding DMA channel y transfer completion flag bit DMA\_ISR. TCy will be set by hardware. If the interrupt is enabled (that is, set DMA\_CSRy.TCIE to 1), an interrupt request will be generated.

# 18.7 Programming examples

## 18.7.1 Asynchronous full-duplex programming examples

### 18.7.1.1 Transmit data in query mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.UARTx to 1, enable the GPIO clock and UART configuration clock corresponding to the UART pin;
- **Step 2**: Configure the UARTx\_TXD pin to the push-pull multiplexed output mode. For the specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set UARTx\_CR1.SYNC to 0, and configure UARTx to be asynchronous full-duplex communication mode;
- Step 4: Configure the data frame;
  - 1. Start bit determination method: configure UARTx\_CR1.START
  - 2. Parity bit: configure UARTx\_CR1.PARITY
  - 3. Stop bit: configure UARTx\_CR1.STOP
- Step 5: Configure UARTx\_CR2.SOURCE and select the transmission clock source;
- Step 6: Configure UARTx\_CR1.OVER and select sampling mode;
- Step 7: Configure the UARTx\_BRRI and UARTx\_BRRF registers and configure the baud rate. For details, please refer to section 18.3.3.2 Fractional baud rate generator;
- Step 8: Set UARTx\_CR1.TXEN to 1 to enable transmit;
- Step 9: Set UARTx\_ICR.TC to 0, clear the transmit completion flag;
- Step 10: Write a frame of data to be transmitted into the UARTx\_TDR register;
- Step 11: Query and wait for the UARTx\_ISR.TC flag to be set to 1 to confirm that one frame of data is transmitted;
- Step 12: Repeat steps 9 ~ 12 to transmit the next frame of data.



## 18.7.1.2 Receive data in query mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.UARTx to 1, enable the GPIO clock and UART configuration clock corresponding to the UART pin;
- Step 2: Configure the RXD pin as the pull-up input multiplexed mode. For the specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set UARTx\_CR1.SYNC to 0, and configure UARTx to be asynchronous full-duplex communication mode;
- Step 4: Configure the data frame;
  - 1. Start bit determination method: configure UARTx\_CR1.START
  - 2. Parity bit: configure UARTx\_CR1.PARITY
  - 3. Stop bit: configure UARTx\_CR1.STOP
- Step 5: Configure UARTx\_CR2.SOURCE and select the transmission clock source;
- **Step 6:** Configure UARTx\_CR1.OVER and select sampling mode;
- Step 7: Configure the UARTx\_BRRI and UARTx\_BRRF registers and configure the baud rate. For details, please refer to section 18.3.3.2 Fractional baud rate generator;
- Step 8: Write 0x00 to the UARTx\_ICR register to clear all flags;
- Step 9: Set UARTx\_CR1.RXEN to 1 to enable receive;
- Step 10: Query and wait for the UARTx\_ISR.RC flag to be set to 1 to confirm that one frame of data has been received;
- Step 11: Query the error flags UARTx\_ISR.PE and UARTx\_ISR.FE to confirm whether the data is valid. If the data is invalid, perform error processing. If the data is valid, read the UARTx\_RDR register and save the data;
- Step 12: Set UARTx\_ICR.RC to 0, clear the reception completion flag;
- Step 13: Repeat steps 10 ~ 13 to receive the next frame of data.

## 18.7.1.3 Transmit data in interrupt mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.UARTx to 1, enable GPIO clock and UART configuration clock corresponding to UART pins;
- Step 2: Configure the TXD pin to the push-pull multiplexed output mode. For the specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set UARTx\_CR1.SYNC to 0, and configure UARTx to be asynchronous full-duplex communication mode;
- Step 4: Configure the data frame;
  - 1. Start bit determination method: configure UARTx\_CR1.START
  - 2. Parity bit: configure UARTx\_CR1.PARITY
  - 3. Stop bit: configure UARTx\_CR1.STOP
- Step 5: Configure UARTx\_CR2.SOURCE and select the transmission clock source;
- Step 6: Configure UARTx\_CR1.OVER and select sampling mode;
- Step 7: Configure the UARTx\_BRRI and UARTx\_BRRF registers and configure the baud rate. For details, For details, please refer to section 18.3.3.2 Fractional baud rate generator;
- Step 8: Configure the NVIC controller, see chapter 5 Interrupt;
- Step 9: Set UARTx\_IER.TXE to 1 to enable transmit buffer empty interrupt;
- Step 10: Set UARTx\_CR1.TXEN to 1 to enable transmit;
- Step 11: Write a frame of data to be transmitted into the UARTx\_TDR register;
- Step 12: The data starts to transmit, the transmit buffer is empty, and the interrupt service function is entered: query and judge the UARTx\_ISR.TXE flag bit, if the flag bit is 1, write a new frame of data to the UARTx\_ TDR register;
- Step 13: Query and wait for the UARTx\_ISR.TXBUSY flag to be cleared and turn off the UART.



#### 18.7.1.4 Receive data in interrupt mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.UARTx to 1, enable the GPIO clock and UART configuration clock corresponding to the UART pin;
- Step 2: Configure the RXD pin as the pull-up input multiplexed mode. For the specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set UARTx\_CR1.SYNC to 0, and configure UARTx to be asynchronous full-duplex communication mode;
- Step 4: Configure the data frame;
  - 1. Start bit determination method: configure UARTx\_CR1.START
  - 2. Parity bit: configure UARTx\_CR1.PARITY
  - 3. Stop bit: configure UARTx\_CR1.STOP
- Step 5: Configure UARTx\_CR2.SOURCE and select the transmission clock source;
- **Step 6:** Configure UARTx\_CR1.OVER and select sampling mode;
- Step 7: Configure the UARTx\_BRRI and UARTx\_BRRF registers and configure the baud rate. For details, please refer to section 18.3.3.2 Fractional baud rate generator;
- Step 8: Configure the NVIC controller, see chapter 5 Interrupt;
- Step 9: Set UARTx\_IER.RC to 1 to enable receive completion interrupt;
- Step 10: Set UARTx\_CR1.RXEN to 1 to enable receive;
- Step 11: Wait for the completion of receiving a frame of data, and enter the interrupt service function: query the UARTx\_ISR.PE and UARTx\_ISR.FE flag bits to confirm whether the data is valid, if invalid, perform error handling; if valid, query and judge the UARTx\_ISR.RC flag bit, If the flag bit is 1, read the UARTx\_RDR register and save the data, and clear the flag bit.

#### 18.7.1.5 DMA transmits data

The following is an example of DMA channel 1 transmit data for UART1 (UART1\_TXD pin is PA08). In this application example, set the transfer clock UCLK to 24MHz, the baud rate to 115200bps, and the DMA data transmission amount to 100. The DMA transmission is started by hardware triggering, and the data in an 8-bit array defined in the SRAM area is transferred to the UART1\_TDR register.

The specific configuration process is as follows:

- **Step 1:** Set SYSCTRL\_AHBEN.GPIOA to 1, SYSCTRL\_APBEN2.UART1 to 1, SYSCTRL\_AHBEN.DMA to 1, enable the configuration clock and working clock of GPIOA, UART1 and DMA respectively;
- Step 2: Configure the UART1\_TXD pin (ie PA08) to push-pull multiplexed output mode. For the specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set UART1\_CR1.SYNC to 0, and configure UART1 to be asynchronous full-duplex communication mode;
- Step 4: Configure the data frame;
  - 1. Start bit determination method: set UART1\_CR1.START to 0, the falling edge of RXD signal
  - 2. Parity bit: set UART1\_CR1.PARITY to 0, no parity
  - 3. Stop bit: configure UART1\_CR1.STOP as 0, 1-bit length of stop bit
- Step 5: Set UART1\_CR2.SOURCE to 0, select the transmission clock source as PCLK=24MHz;
- Step 6: Set UART1\_CR1.OVER to 0, select 16 times sampling mode;
- Step 7: Set UART1\_BRRI.BRRI to 0x0D, UART1\_BRRF.BRRF to 0x00, configure baud rate to 115200bps;
- Step 8: Set UART1\_CR1.TXEN to 1 to enable transmission;
- Step 9: Define a variable uint8\_t SendBuff[100], and assign it;
- Step 10: Write 0x00 to UART1\_ICR to clear all flag bits of UART1;
- Step 11: Set DMA\_ICR.TC1 and DMA\_ICR.TE1 to 0, clear all interrupt flags of DMA channel 1;
- Step 12: Set DMA\_SRCADDR1= (uint32\_t) SendBuff, the source address is SendBuff;
- Step 13: Set DMA\_DSTADDR1= (uint32\_t) &UART1\_TDR, the destination address is the UART1\_TDR register;
- Step 14: Set DMA\_CSR1.SRCINC to 1, the source address is incremented automatically;
- Step 15: Set DMA\_CSR1.DSTINC to 0, the destination address is fixed;
- Step 16: Write 0x10064 to DMA\_CNT1, and the data transmission amount is 100;
- Step 17: Set DMA\_CSR1.SIZE to 0, and the transmission data bit width to 8 bits;
- Step 18: Set DMA\_CSR1.TRANS to 1, block transmission (BLOCK);
- Step 19: Set DMA\_TRIG1.Type to 1, hardware trigger mode;
- Step 20: Set DMA\_TRIG1. HardSrc to 0x01, trigger DMA transmissionr when UART1\_TDR register is empty;
- Step 21: Set DMA\_CSR1.EN to 1 to enable DMA channel 1 transmit;
- Step 22: Set UART1\_CR2.DMATX to 1, and enable the DMA hardware handshake logic of UART1 TXD;
- Step 23: Query and wait for DMA\_ISR.TC1 to become 1 to confirm that the DMA transmission is completed;
- Step 24: Set UART1\_CR2.DMATX to 0, and turn off the DMA hardware handshake logic of UART1 TXD;
- Step 25: Query and wait for UART1\_ISR.TXBUSY to become 0, confirm that the data has been transmitted through UART1;
- Step 26: Repeat steps 9 ~ 26 if new data is to be transferred.



#### 18.7.1.6 DMA receives data

The following is an example of DMA channel 2 receive data for UART1 (UART1\_RXD pin is PA09). In this application example, the transmission clock UCLK is set to 24MHz, the baud rate is 115200bps, and the DMA data transmission amount is 100. The DMA transmission is started by hardware triggering, and the data in the UART1\_RDR register is transferred to an 8-bit array in the SRAM area.

The specific configuration process is as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOA to 1, SYSCTRL\_APBEN2.UART1 to 1, SYSCTRL\_AHBEN.DMA to 1, enable the configuration clock and working clock of GPIOA, UART1 and DMA respectively;
- Step 2: Configure the UART1\_RXD pin (that is, PA09) as the pull-up multiplexing input mode. For the specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set UART1\_CR1.SYNC to 0, and configure UART1 to be asynchronous full-duplex communication mode;
- Step 4: Configure the data frame;
  - 1. Start bit determination method: set UART1\_CR1.START to 0, the falling edge of RXD signal
  - 2. Parity bit: set UART1\_CR1.PARITY to 0, no parity
  - 3. Stop bit: configure UART1\_CR1.STOP as 0, 1-bit length of stop bit
- Step 5: Set UART1\_CR2.SOURCE to 0, select the transmission clock source as PCLK=24MHz;
- Step 6: Set UART1\_CR1.OVER to 0, select 16 times sampling mode;
- Step 7: Set UART1\_BRRI.BRRI to 0x0D, UART1\_BRRF.BRRF to 0x00, configure baud rate to 115200bps;
- Step 8: Set UART1\_CR1.RXEN to 1 to enable reception;
- Step 9: Define a variable uint8\_t RecvBuff[100];
- Step 10: Write 0x00 to UART1\_ICR to clear all flag bits of UART1;
- Step 11: Set DMA\_ICR.TC2 and DMA\_ICR.TE2 to 0, clear all interrupt flags of DMA channel 2;
- Step 12: Set DMA\_SRCADDR2= (uint32\_t) &UART1\_RDR, the source address is the UART1\_RDR register;
- Step 13: Set DMA\_DSTADDR2=( uint32\_t ) RecvBuff, the destination address is RecvBuff;
- Step 14: Set DMA\_CSR2.SRCINC to 0, the source address is fixed;
- Step 15: Set DMA\_CSR2.DSTINC to 1, and the destination address is incremented automatically;
- Step 16: Write 0x10064 to DMA\_CNT2, and the data transmission amount is 100;
- Step 17: Set DMA\_CSR2.SIZE to 0, and the transmission data bit width to 8 bits;
- Step 18: Set DMA\_CSR2.TRANS to 1, block transmission (BLOCK);
- **Step 19:** Set DMA\_TRIG2.Type to 1, hardware trigger mode;
- Step 20: Set DMA\_TRIG2. HardSrc to 0x00, trigger DMA transmission when UART1\_RDR register is not empty;
- Step 21: Set DMA\_CSR2.EN to 1 to enable DMA channel 2 transmit;
- Step 22: Set UART1\_CR2.DMARX to 1, and enable the DMA hardware handshake logic of UART1 RXD;
- Step 23: Query and wait for DMA\_ISR.TC2 to become 1 to confirm that the DMA transfer is completed;
- Step 24: Set UART1\_CR2.DMARX to 0, and disable the DMA hardware handshake logic of UART1 RXD;
- Step 25: Repeat steps 10 ~ 25 if new data is to be transferred.



#### 18.7.2 Synchronous half-duplex programming examples

## 18.7.2.1 Transmit data in query mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.UARTx to 1, enable GPIO clock and UART configuration clock;
- Step 2: Configure the UARTx\_TXD and UARTx\_RXD pins as push-pull multiplexed output mode, and configure the slave chip select pin NCS as push-pull output mode. For the specific register configuration steps, please refer to chapter 9 General-purpose input/output (GPIO);
- Step 3: Set UARTx\_CR1.SYNC to 1, and configure UARTx to be synchronous half-duplex communication mode;
- **Step 4:** Configure UARTx\_CR2.SOURCE, select the transmission clock source, and configure the baud rate. For details, please refer to chapter *18.3.2 Synchronous mode*;
- Step 5: Pull down the NCS signal and select a slave;
- Step 6: Set UARTx\_CR1.TXEN to 1 to enable transmit;
- Step 7: Set UARTx\_ICR.TC to 0, and clear the transmission completion flag;
- Step 8: Write the 8-bit data to be transmitted to the UARTx\_TDR register;
- Step 9: Query and wait for the UARTx\_ISR.TC flag bit to be set to 1 to confirm that the data transmission is completed;
- Step 10: Repeat steps 7 ~ 10 to transmit the next frame of data;
- Step 11: Pull up the NCS signal to end the communication.

## 18.7.2.2 Receive data in query mode

- **Step 1:** Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.UARTx to 1, enable GPIO clock and UART configuration clock;
- Step 2: Configure the UARTx\_TXD and UARTx\_RXD pins as push-pull multiplexed output mode, and configure the slave chip select pin NCS as push-pull output mode. For the specific register configuration steps, please refer to chapter 9 General-purpose input/output (GPIO);
- Step 3: Set UARTx\_CR1.SYNC to 1, and configure UARTx to be synchronous half-duplex communication mode;
- **Step 4:** Configure UARTx\_CR2.SOURCE, select the transmission clock source, and configure the baud rate. For details, please refer to section *18.3.2 Synchronous mode*;
- Step 5: Pull down the NCS signal and select a slave;
- Step 6: Write 0x00 to UARTx\_ICR to clear all flags;
- Step 7: Set UARTx\_CR1.RXEN to 1 to enable reception;
- Step 8: Query and wait for the UARTx\_ISR.RC flag to be set to 1 to confirm that the data reception is completed;
- Step 9: Read the UARTx\_RDR register and save the data;
- Step 10: Set UARTx\_ICR.RC to 0, clear the reception completion flag;
- Step 11: Repeat steps 8 ~ 11 to receive the next 8-bit data;
- Step 12: Pull up the NCS signal to end the communication.



#### 18.7.3 Single-wire half-duplex programming examples

#### 18.7.3.1 Transmit data in query mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.UARTx to 1, enable the GPIO clock and UART configuration clock corresponding to the UART pin;
- Step 2: Configure the UARTx\_TXD pin to open-drain multiplexed output mode, and connect an external pull-up resistor. For the specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set UARTx\_CR2.SIGNAL to 1, and configure UARTx to be single-wire half-duplex communication mode;
- Step 4: Configure the data frame;
  - 1. Start bit determination method: configure UARTx\_CR1.START
  - 2. Parity bit: configure UARTx\_CR1.PARITY
  - 3. Stop bit: configure UARTx\_CR1.STOP
- **Step 5**: Configure UARTx\_CR2.SOURCE and select the transmission clock source;
- **Step 6:** Configure UARTx\_CR1.OVER and select sampling mode;
- **Step 7:** Configure the UARTx\_BRRI and UARTx\_BRRF registers and configure the baud rate. For details, please refer to section *18.3.3.2 Fractional baud rate generator*;
- Step 8: Set UARTx\_CR1.TXEN to 1 and UARTx\_CR1.RXEN to 1 to enable transmit and receive;
- Step 9: Set UARTx\_ICR.TC to 0, and clear the transmission completion flag;
- Step 10: Write a frame of data to be transmitted into the UARTx\_TDR register;
- Step 11: Query and wait for the UARTx\_ISR.TC flag bit to be set to 1 to confirm that the data transmission is completed;
- Step 12: Repeat steps 9 ~ 12 to transmit the next frame of data.



#### 18.7.3.2 Receive data in query mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBENx.UARTx to 1, enable the GPIO clock and UART configuration clock corresponding to the UART pin;
- Step 2: Configure the UARTx\_TXD pin to open-drain multiplexed output mode, and connect an external pull-up resistor. For the specific register configuration steps, please refer to chapter 9 General-purpose input/output (GPIO);
- Step 3: Set UARTx\_CR2.SIGNAL to 1, and configure UARTx to be single-wire half-duplex communication mode;
- Step 4: Configure the data frame;
  - 1. Start bit determination method: configure UARTx\_CR1.START
  - 2. Parity bit: configure UARTx\_CR1.PARITY
  - 3. Stop bit: configure UARTx\_CR1.STOP
- Step 5: Configure UARTx\_CR2.SOURCE and select the transmission clock source;
- Step 6: Configure UARTx\_CR1.OVER and select sampling mode;
- **Step 7:** Configure the UARTx\_BRRI and UARTx\_BRRF registers and configure the baud rate. For details, please refer to section *18.3.3.2 Fractional baud rate generator*;
- Step 8: Write 0x00 to UARTx\_ICR to clear all flags;
- Step 9: Set UARTx\_CR1.TXEN to 1 and UARTx\_CR1.RXEN to 1 to enable transmit and receive;
- Step 10: Query and wait for the UARTx\_ISR.RC flag to be set to 1 to confirm that one frame of data has been received;
- Step 11: Query the error flags UARTx\_ISR.PE and UARTx\_ISR.FE to confirm whether the data is valid. If the data is invalid, perform error processing. If the data is valid, read the UARTx\_RDR register and save the data;
- Step 12: Set UARTx\_ICR.RC to 0, clear the reception completion flag;
- Step 13: Repeat steps 10 ~ 13 to receive the next frame of data.

# 18.8 List of registers

UART1 base address: UART1\_BASE = 0x4001 3800 UART2 base address: UART2\_BASE = 0x4000 4400 UART3 base address: UART3\_BASE = 0x4000 4800

Table 18-12 List of UART registers

| Register name | Register address   | Register description                       |
|---------------|--------------------|--------------------------------------------|
| UARTx_CR1     | UARTx_BASE + 0x00  | Control register 1                         |
| UARTx_CR2     | UARTx _BASE + 0x04 | Control register 2                         |
| UARTx_IER     | UARTx_BASE + 0x08  | Interrupt enable register                  |
| UARTx_BRRI    | UARTx_BASE + 0x0C  | Baud rate counter integer part register    |
| UARTx_BRRF    | UARTx_BASE + 0x10  | Baud rate counter fractional part register |
| UARTx_TIMARR  | UARTx_BASE + 0x14  | Timer reload register                      |
| UARTx_TIMCNT  | UARTx_BASE + 0x18  | Timer count register                       |
| UARTx_ISR     | UARTx_BASE + 0x1C  | Interrupt flag register                    |
| UARTx_ICR     | UARTx_BASE + 0x20  | Interrupt flag clear register              |
| UARTx_RDR     | UARTx_BASE + 0x24  | Receive data register                      |
| UARTx_TDR     | UARTx_BASE + 0x28  | Transmit data register                     |
| UARTx_ADDR    | UARTx_BASE + 0x30  | Slave address register                     |
| UARTx_MASK    | UARTx_BASE + 0x34  | Slave address mask register                |

# 18.9 Register descriptions

See section  ${\it 1 \, Documentation \, conventions}$  for abbreviations used in register descriptions.

# 18.9.1 UARTx\_CR1 control register 1

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13     | RFU   | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                              |
| 12        | BRKL  | RW         | Length threshold for receiving Break Field in LIN mode 0: 10bit 1: 11bit                                                                                                                                                                                                                                                                                                                                                  |
| 11        | TXBRK | RW         | Sending Break Field in LIN mode. Set by software only when the Break Field is to be sent and cleared by hardware when the transmission is complete.  0: Break Field transmission complete  1: Send Break Field                                                                                                                                                                                                            |
| 10:9      | OVER  | RW         | Sampling mode settings 00: 16 times sampling, Baud = UCLK/(BRRI×16+BRRF) 01: 8 times sampling, Baud = UCLK/(BRRI×8) 10: 4 times sampling, Baud = UCLK/(BRRI×4) 11: dedicated sampling, Baud = UCLK×256/BRRI Caution 1: Dedicated sampling is only suitable for 2400, 4800, 9600 communication when the transmission clock is LSI/LSE Caution 2: When BRRF is a non-zero value, 16 times sampling is automatically adopted |
| 8         | START | RW         | RXD signal START bit determination mode settings 0: RXD signal falling edge 1: RXD signal low level                                                                                                                                                                                                                                                                                                                       |
| 7         | LIN   | RW         | LIN mode enable control 0: Working in UART mode 1: Working in LIN mode                                                                                                                                                                                                                                                                                                                                                    |
| 6         | SYNC  | RW         | Transmission sync-async mode settings 0: Working in asynchronous mode 1: Working in synchronous mode Caution: SYNC bit must be cleared in LIN mode                                                                                                                                                                                                                                                                        |
| 5:4       | STOP  | RW         | Stop bit length settings 00: 1 bit 01: 1.5 bit 10: 2 bit 11: Reserved Caution 1: STOP bit must be cleared in synchronous mode. Caution 2: STOP bit must be cleared in LIN mode.                                                                                                                                                                                                                                           |

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2       | PARITY | RW         | Check digit settings 00: No parity 01: Custom check 10: Even parity 11: Odd parity Caution 1: When there is no parity check, the data word length is 8 bits; when there is a check bit, the data word length is 9 bits; Caution 2: In the multi-computer communication mode, both the master and the slave are configured as custom check. Caution 3: PARITY bit must be cleared in LIN mode. |
| 1         | RXEN   | RW         | Receive circuit enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                         |
| 0         | TXEN   | RW         | Transmit circuit enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                        |

# 18.9.2 UARTx\_CR2 control register 2

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------|--------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13     | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12:10     | TIMCR  | RW         | Timer operating mode configuration 000: Stop timer 010: Wait for timeout detection mode Immediately start the timer to count from 0 and start counting from 0 every time a STOP bit is received; the counting clock is baud rate clock; it stops automatically after timeout. 011: Receive idle detection mode Count from 0 for each STOP bit received; count clock is baud rate clock; stops automatically after timeout. 101: Automatic baud rate detection mode 1 Falling edge of RXD causes timer to start counting from 0, rising edge stops timer; counting clock is UCLK; stops automatically when detection is complete. 110: Automatic baud rate detection mode 2 Falling edge of RXD enables timer to start counting from 0, 4th falling edge stops timer; counting clock is UCLK; stops automatically when detection is complete. 111: General purpose timing function Immediately start the timer to count from 0; count clock is UCLK; stops automatically start the timer to count from 0; count clock is UCLK; stops automatically after timeout (TIMARR+2) UCLK. |
| 9:8       | SOURCE | RW         | UART transmission clock source configuration 00: UCLK is from PCLK 01: UCLK is from PCLK 10: UCLK is from LSE 11: UCLK is from LSI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7         | DMATX  | RW         | DMA transmit data enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6         | DMARX  | RW         | DMA receive data enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5         | TXINV  | RW         | TXD pin outputs signal inversion control 0: The TXD pin outputs the non-inverting signal 1: The TXD pin outputs the inverted signal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4         | RXINV  | RW         | RXD pin inputs signal inversion control 0: The RXD pin signal is directly transmitted to the receiving circuit 1: The RXD pin signal is inverted and transmitted to the receiving circuit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                    |
|-----------|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3         | RTSEN  | RW         | RTS hardware signal enable control 0: Disabled 1: Enabled                                                                                                                                                               |
| 2         | CTSEN  | RW         | CTS hardware signal enable control 0: Disabled 1: Enabled                                                                                                                                                               |
| 1         | SIGNAL | RW         | Single bus mode enable control 0: Disabled, transmit data through TXD port and receive data through RXD port 1: Enabled, transmit and receive data through the TXD port Caution: SIGNAL bit must be cleared in LIN mode |
| 0         | ADDREN | RW         | Slave address recognition enable control 0: Disabled 1: Enabled                                                                                                                                                         |

# 18.9.3 UARTx\_BRRI baud rate counter integer part register

Address offset: 0x0C Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value |
| 15:0      | BRRI | RW         | Baud rate counter integer part               |

# 18.9.4 UARTx\_BRRF baud rate counter fractional register

Address offset: 0x10 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:4      | RFU  | -          | Reserved bits, please keep the default value |
| 3:0       | BRRF | RW         | Baud rate counter fractional part            |

# 18.9.5 UARTx\_TIMARR Timer reload register

Address offset: 0x14 Reset value: 0x00FF FFFF

| Bit field | Name   | Permission | Function description                         |
|-----------|--------|------------|----------------------------------------------|
| 31:24     | RFU    | -          | Reserved bits, please keep the default value |
| 23:0      | TIMARR | RW         | Timer reload values                          |



# 18.9.6 UARTx\_TIMCNT Timer count register

Address offset: 0x18 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                         |
|-----------|--------|------------|----------------------------------------------|
| 31:24     | RFU    | -          | Reserved bits, please keep the default value |
| 23:0      | TIMCNT | RO         | Timer count values                           |

# 18.9.7 UARTx\_TDR transmit data register

Address offset: 0x28 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                          |
|-----------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                  |
| 8:0       | TDR  | WO         | Data to be transmitted Caution1: When UARTX_CR1.PARITY is set to a custom verification, the TXD pin will send UARTx_TDR[8] Caution2: When sending Break Field in LIN mode, the data written to this register is used as the number of bits in the Break Field |

# 18.9.8 UARTx\_RDR receive data register

Address offset: 0x24 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                          |  |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------------------------|--|
| 31:9      | RFU  | -          | Reserved bits, please keep the default value                                                                                  |  |
| 8:0       | RDR  | RO         | Received data Caution: When UARTx_CR1.PARITY is set to a custom verification, the receiving circuit will receive UARTx_TDR[8] |  |

# 18.9.9 UARTx\_IER interrupt enable register

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                                       |  |
|-----------|-------|------------|--------------------------------------------------------------------------------------------|--|
| 31:12     | RFU   | -          | Reserved bits, please keep the default value                                               |  |
| 11        | RXBRK | RW         | Break Field reception complete in LIN mode interrupt enable control 0: Disabled 1: Enabled |  |
| 10        | BAUD  | RW         | Automatic baud rate detection complete interrupt enable control 0: Disabled 1: Enabled     |  |
| 9         | TIMOV | RW         | Timer overflow interrupt enable control 0: Disabled 1: Enabled                             |  |
| 8:7       | RFU   | -          | Reserved bits, please keep the default value                                               |  |
| 6         | CTS   | RW         | CTS signal change interrupt enable control 0: Disabled 1: Enabled                          |  |
| 5         | RFU   | -          | Reserved bits, please keep the default value                                               |  |
| 4         | PE    | RW         | Parity check error interrupt enable control 0: Disabled 1: Enabled                         |  |
| 3         | FE    | RW         | Frame structure error interrupt enable control 0: Disabled 1: Enabled                      |  |
| 2         | RC    | RW         | Receive completion interrupt enable control 0: Disabled 1: Enabled                         |  |
| 1         | TC    | RW         | Transmit completion interrupt enable control 0: Disabled 1: Enabled                        |  |
| 0         | TXE   | RW         | Transmit buffer empty interrupt enable control 0: Disabled 1: Enabled                      |  |

# 18.9.10 UARTx\_ISR interrupt flag register

Address offset: 0x1C Reset value: 0x0000 0001

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                               |  |
|-----------|--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:12     | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                       |  |
| 11        | RXBRK  | RO         | Break Field reception complete in LIN mode interrupt flag 0: Break Field not received 1: Break Field has been received                                                                                                                                             |  |
| 10        | BAUD   | RO         | Automatic baud rate detection complete interrupt flag 0: Automatic baud rate detection not completed 1: Automatic baud rate detection has been completed                                                                                                           |  |
| 9         | TIMOV  | RO         | Timer overflow interrupt flag 0: Timer has not overflowed (TIMCNT < TIMARR) 1: Timer has overflowed (TIMCNT ≥ TIMARR)                                                                                                                                              |  |
| 8         | TXBUSY | RO         | TXD transmitting status 0:TDR register and transmit shift register are empty 1:TDR register or transmit shift register is not empty                                                                                                                                |  |
| 7         | CTSLV  | RO         | CTS signal level status 0: CTS signal is low level 1: CTS signal is high level                                                                                                                                                                                     |  |
| 6         | CTS    | RO         | CTS signal change interrupt flag 0: No CTS level change detected 1: CTS level change has been detected                                                                                                                                                             |  |
| 5         | MATCH  | RO         | Slave address match flag 0: No match address was detected. 1: The match address has been detected                                                                                                                                                                  |  |
| 4         | PE     | RO         | Parity check error interrupt flag  0: No parity check error was detected  1: Parity check error has been detected                                                                                                                                                  |  |
| 3         | FE     | RO         | Frame structure error interrupt flag 0: No frame structure error was detected 1: The frame structure error has been detected                                                                                                                                       |  |
| 2         | RC     | RO         | Receive completion interrupt flag  0: The reception of a frame of data has not been completed  1: The reception of a frame of data has been completed                                                                                                              |  |
| 1         | TC     | RO         | Transmit completion interrupt flag The transmit shift register is set by hardware when the transmission of a frame of data is completed.  0: The transmission of a frame of data has not been completed  1: The transmission of a frame of data has been completed |  |

| Bit field | Name | Permission | Function description                                                                                                                                              |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0         | TXE  | RO         | Transmit buffer empty flag  0: There is data in the transmit buffer  1: No data in transmit buffer  Caution: Write the uartx_tdr register will clear the flag bit |

# 18.9.11 UARTx\_ICR interrupt flag clear register

Address offset: 0x20 Reset value: 0x0000 0FFF

| Bit field | Name  | Permission | Function description                                                                                                                                       |  |
|-----------|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:12     | RFU   | -          | Reserved bits, please keep the default value                                                                                                               |  |
| 11        | RXBRK | R1W0       | Clear control of Break Field reception complete in LIN mode interrupt flag W0: Break Field receive completion interrupt flag cleared W1: No function       |  |
| 10        | BAUD  | R1W0       | Clear control of automatic baud rate detection complete interrupt flag W0: Automatic baud rate detection completion interrupt flag cleared W1: No function |  |
| 9         | TIMOV | R1W0       | Clear control of timer overflow interrupt flag<br>W0: Timer overflow interrupt flag cleared<br>W1: No function                                             |  |
| 8:7       | RFU   | -          | Reserved bits, please keep the default value                                                                                                               |  |
| 6         | CTS   | R1W0       | Clear control of CTS signal change interrupt flag<br>W0: CTS signal change interrupt flag cleared<br>W1: No function                                       |  |
| 5         | RFU   | -          | Reserved bits, please keep the default value                                                                                                               |  |
| 4         | PE    | R1W0       | Clear control of parity check error interrupt flag<br>W0: Parity check error interrupt flag cleared<br>W1: No function                                     |  |
| 3         | FE    | R1W0       | Clear control of frame error interrupt flag<br>W0: Frame structure error interrupt flag cleared<br>W1: No function                                         |  |
| 2         | RC    | R1W0       | Clear control of receiving completion interrupt flag<br>W0: Receive completion interrupt flag cleared<br>W1: No function                                   |  |
| 1         | TC    | R1W0       | Clear control of transmitting completion interrupt flag<br>W0: Transmit completion interrupt flag cleared<br>W1: No function                               |  |
| 0         | RFU   | -          | Reserved bits, please keep the default value                                                                                                               |  |

# 18.9.12 UARTx\_ADDR slave address register

Address offset: 0x30 Reset value: 0x0000 0000

| Bit field | Name | Permission                                     | Function description   |  |
|-----------|------|------------------------------------------------|------------------------|--|
| 31:8      | RFU  | - Reserved bits, please keep the default value |                        |  |
| 7:0       | ADDR | RW                                             | Slave address register |  |

# 18.9.13 UARTx\_MASK slave address mask register

Address offset: 0x34 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |  |
|-----------|------|------------|----------------------------------------------|--|
| 31:8      | RFU  | -          | Reserved bits, please keep the default value |  |
| 7:0       | MASK | RW         | Slave address mask register                  |  |



# 19 Serial peripheral interface (SPI)

#### 19.1 Overview

Serial peripheral interface (SPI) is a synchronous serial data communication interface, which is often used for synchronous serial communication between MCU and external devices. CW32W031 integrates one serial peripheral SPI interfaces, supports bidirectional full-duplex, single-wire half-duplex and simplex communication modes, can configure MCU as master or slave, supports multi-master communication mode, supports direct memory access (DMA).

The SPI communication interface is internally connected to the RF subsystem on the chip, so the SPI function on the external pins of the chip is not available when using the RF function.

#### 19.2 Main features

- Supports master mode, slave mode
- Supports full-duplex, single-wire half-duplex, simplex
- Selectable 4 to 16 bit data frame width
- Supports sending and receiving data LSB or MSB first
- Programmable clock polarity and clock phase
- Communication rates up to PCLK/4 in master mode
- Communication rates up to PCLK/4 in slave mode
- Supports multi-computer communication mode
- 8 interrupt sources with flag bits
- Supports direct memory access (DMA)

# 19.3 Functional description

#### 19.3.1 Functional block diagram

The functional block diagram of the SPI controller is shown in the following figure:

Sending buffer area

Shift register

MOSI

MISO

Receiving buffer area

Baud rate generator

SCK

Slave Select Management

CS

Figure 19-1 SPI functional block diagram

SPI is generally connected to external devices through 4 pins:

- MOSI
  - Master output/slave input, used for data transmission in master mode and data reception in slave mode;
- MISO
  - Master input/slave output, used for data reception in master mode and data transmission in slave mode;
- SCK
  - Synchronous serial clock, master clock output and slave clock input, transmit or receive master synchronous clock;
- CS
  - Slave selection is also used for bus conflict detection in multi-computer communication. Refer to section *19.3.3 Slave select pin CS*.

CW32W031 supports the user to flexibly select GPIO as the SPI communication pin, which is realized by multiplexing the AFR function, please refer to the pin definitions in the Datasheet.

SPI supports a variety of operating modes. In different operating modes, each pin has different functions. The pin configuration is shown in the following table:

Table 19-1 SPI ports configuration

| SPI pins | Mode configuration                  | Function                               | GPIO configuration                     |
|----------|-------------------------------------|----------------------------------------|----------------------------------------|
| CDL CCK  | Master                              | Serial clock output                    | Digital, push-pull output, multiplexed |
| SPI_SCK  | Slave                               | Serial clock input                     | Digital, floating input, multiplexed   |
|          | Full duplex/master                  | Master data output                     | Digital, push-pull output, multiplexed |
|          | Full duplex/slave                   | Slave data input                       | Digital, floating input, multiplexed   |
|          | Single-wire half-duplex/<br>master  | Master data transmitting and receiving | Digital, push-pull output, multiplexed |
|          | Single-wire half-duplex/<br>slave   | Do not use                             | Can be used as general purpose I/O     |
| SPI_MOSI | Simplex single transmitting/master  | Master data output                     | Digital, push-pull output, multiplexed |
|          | Simplex single transmitting/slave   | Do not use                             | Can be used as general purpose I/O     |
|          | Simplex single receiving/<br>master | Do not use                             | Can be used as general purpose I/O     |
|          | Simplex single receiving/<br>slave  | Slave data input                       | Digital, floating input, multiplexed   |
|          | Full duplex/master                  | Master data input                      | Digital, floating input, multiplexed   |
|          | Full duplex/slave                   | Slave data output                      | Digital, push-pull output, multiplexed |
|          | Single-wire half-duplex/<br>master  | Do not use                             | Can be used as general purpose I/O     |
|          | Single-wire half-duplex/<br>slave   | Slave data transmission and reception  | Digital, push-pull output, multiplexed |
| SPI_MISO | Simplex single transmitting/master  | Do not use                             | Can be used as general purpose I/O     |
|          | Simplex single transmitting/slave   | Slave data output                      | Digital, push-pull output, multiplexed |
|          | Simplex single receiving/<br>master | Master data output                     | Digital, push-pull output, multiplexed |
|          | Simplex single receiving/<br>slave  | Do not use                             | Can be used as general purpose I/O     |
|          | Master (SSM=0)                      | Slave select input                     | Digital, floating input, multiplexed   |
| SDI CC   | Master (SSM=1)                      | Slave select output                    | Digital, push-pull output, multiplexed |
| SPI_CS   | Slave (SSM=0)                       | Slave select input                     | Digital, floating input, multiplexed   |
|          | Slave (SSM=1)                       | Do not use                             | Can be used as general purpose I/O     |

## 19.3.2 Communication timing and data format

#### **Communication timing**

The following figure shows the communication timing of SPI. The CS, SCK, and MOSI signals are all controlled by the master, and the MISO signal is the slave response signal. The slave selects the CS signal from high level to low level, which is the start signal of SPI communication. When the slave detects the start signal, it starts to communicate with the master. In each SCK clock cycle, the MOSI and MISO signal lines transmit one bit of data. CS changes from low level to high, which is the stop signal of communication, indicating the end of this communication.



Figure 19-2 SPI communication timing

# Data frame format

The data frame width is configured by the WIDTH bit field of the control register SPI\_CR1, which can be set to any data bit width from 4 to 16 bits.

The size of the data is configured by the LSBF bit field of the control register SPI\_CR1, and the most significant bit first (MSB) or the least significant bit first (LSB) can be selected.



**Rev 1.0** 

## Clock frequency

The synchronous serial clock SCK signal is controlled and generated by the SPI host, and its clock source is PCLK. The frequency division factor is set by configuring the BR bit field of the control register SPI\_CR1, and the frequency division can be selected from 2 to 128. For SPI slaves, configuring SPI\_CR1.BR has no effect.

#### Clock polarity, clock phase

Clock polarity CPOL refers to the level state of the SCK serial clock line when the device is in an idle state without data transmission. Configure through the CPOL bit field of the control register SPI\_CR1: set SPI\_CR1. CPOL to 0, and the SCK clock line is low when it is idle; set SPI\_CR1.CPOL to 1, and the SCK clock line is high when it is idle.

The clock phase CPHA refers to the sampling and shifting moment of the data. Configure through the CPHA of the control register SPI\_CR1: set SPI\_CR1.CPHA to 0, sample on the front edge of SCK (the clock edge when SCK changes from idle state to non-idle state), and the trailing edge (SCK changes from non-idle state to idle state). Clock edge) shift; set SPI\_CR1.CPHA to 1, shift on the leading edge of SCK, and sample on the trailing edge.

According to the different configurations of clock polarity CPOL and clock phase CPHA, SPI can set 4 level modes. The master and slave need to be configured to the same level mode to ensure normal communication.

| CPOL | СРНА | SCK clock when idle | Sampling time |
|------|------|---------------------|---------------|
| 0    | 0    | Low level           | Front edge    |
| 0    | 1    | Low level           | Back edge     |
| 1    | 0    | High level          | Front edge    |
| 1    | 1    | High level          | Back edge     |

Table 19-2 SPI level mode

#### 19.3.3 Slave select pin CS

The following figure shows a schematic diagram of the configuration management of slave select pin CS. In master mode, CS can be selected as input or output. When used as input, it is used to detect bus conflicts in multi-master mode, and when used as output, it is used to generate slave chip select signals. In slave mode, CS acts as a device chip select input.

CS Chip selection output SSI

Figure 19-3 Slave select pin management

In master and slave mode, the slave select CS is managed by the SSM bit field of the control register SPI\_CR1.

# CS pin in master mode

Set SPI\_CR1.SSM to 0, and CS is configured as an input to detect whether there is a bus conflict in the multi-computer communication system (Caution that the master needs to select the slave to communicate through other GPIOs at this time), please refer to section 19.3.7 Multi-machine communication.

Setting SPI\_CR1.SSM to 1, the slave select pin CS is configured as an output for generating the slave select signal. The CS pin output level is determined by the SSI bit field of the slave select register SPI\_SSI: set SPI\_SSI. SSI to 1, CS outputs a high level; set SPI\_SSI.SSI to 0, CS outputs a low level.

#### CS pin in slave mode

Set SPI\_CR1.SSM to 0 to use CS signal as device select. The CS level determines whether this unit is selected: when CS is low level, this unit is selected; when CS is high level, this unit is deselected.

Set SPI\_CR1.SSM to 1, do not use CS as the device selection, the slave select is determined by the SSI bit field value of the SPI\_SSI register. Set SPI\_SSI.SSI to 0, this machine is selected; set SPI\_SSI.SSI to 1, this machine is unchecked. In this configuration, the user program sets whether the machine is selected by software, and the CS pin can be used as a common IO.

#### 19.3.4 Full-duplex mode

SPI supports full-duplex communication mode. In this mode, the shift registers of the master and slave are connected through two unidirectional data lines, MOSI and MISO, and two lines of data are simultaneously performed under the control of the SCK clock signal provided by the host. transmission.

Set the MODE bit field of the control register SPI\_CR1 to 0x0 to make the SPI work in full-duplex communication mode.

A typical application block diagram of full-duplex mode is shown in the following figure:

Shift register

MISO

MISO

SPI clock
generator

Master

CS

CS

Slave

Figure 19-4 Full-duplex communication mode

#### Master transmits and receives

Set SPI\_CR1.MSTR to 1, SPI works in master mode.

The master sets SPI\_SSI.SSI to 0, and the slave selects the CS pin to output a low level as the communication start signal.

When the transmit buffer is empty, that is, the SPI\_ISR.TXE flag is 1, write a frame of data to be sent into the SPI\_DR register, the data is output from the MOSI pin under the control of the synchronous shift clock signal, and the MISO pin is simultaneously pin data is received into the shift register. At the end of transmitting a data frame, the non-empty flag bit SPI\_ISR.RXNE of the receive buffer is set to 1 by hardware, indicating that a frame of data has been received, and the SPI\_DR register can be read at this time.

Set SPI SSI.SSI to 1, and the slave select pin CS outputs a high level to end this communication.



Figure 19-5 Master transmit and receive timing in full-duplex mode (two bytes)

#### Slave transmits and receives

Set SPI CR1.MSTR to 0, SPI works in slave mode.

Before the slave select CS signal is pulled low, the slave needs to set SPI\_ICR.FLUSH to 0 to clear the transmit buffer and shift register, and write the first frame data to be transmitted into the SPI\_DR register.

When the CS signal is pulled low, the written data will be output from the MISO pin under the control of the master's synchronous shift clock signal, and at the same time receive the data from the MOSI pin to the shift register.

If it is continuous communication of multiple data frames, the user should continuously query the SPI\_ISR.TXE flag bit. Once the flag is 1, immediately write the data to be transmitted into the SPI\_DR register to avoid data leakage.

When the receive buffer is not empty, that is, the SPI\_ISR.RXNE flag is 1, indicating that a frame of data has been received, and the SPI\_DR register can be read at this time.

This communication ends when it is detected that the CS pin changes to a high level.

CPOL=0,CPHA=0

Write DR

SCK

MOSI

MISO

ISR.TXE

ISR.RXNE

Read DR

Figure 19-6 Slave transmit and receive timing in full-duplex mode (two bytes)

#### 19.3.5 Single-wire half-duplex mode

SPI supports single-wire half-duplex communication mode. In this mode, the master and slave communicate data through a bidirectional data line. The master uses MOSI, the slave uses MISO, and other unused SPI signal lines can be used by other functions.

Set the MODE bit field of the control register SPI\_CR1 to 0x3 to make the SPI work in single-wire half-duplex mode.

The HDOE bit field of the control register SPI\_CR2 selects the transmitting and receiving direction. When HDOE is 0, it is only received, and when HDOE is 1, it is only transmitted.

A typical application block diagram of single-wire half-duplex mode is shown in the following figure:



Figure 19-7 Single-wire half-duplex mode

During single-wire half-duplex communication, since the communication directions of the master and the slave cannot be guaranteed to switch synchronously, there may be a driving conflict and cause device damage. It is recommended to connect a resistor in series on the data line between the master and the slave to limit the current.

When the SPI is used as a slave, the single-wire half-duplex mode can be used to communicate with a standard UART transceiver in synchronous mode. At this time, the SPI must be configured as a fixed level mode: the clock polarity CPOL is 1, and the clock phase is CPHA. is 1.

#### Master transmits

Set SPI\_CR1.MSTR to 1, SPI works in master mode; set SPI\_CR2.HDOE to 1, the master only transmits data.

The master sets SPI\_SSI.SSI to 0, and outputs a low level on the slave selection pin CS as a communication start signal.

When the transmit buffer is empty, that is, the SPI\_ISR.TXE flag bit is 1, a frame of data to be transmitted is written into the SPI\_DR register, and the data is output from the MOSI pin under the control of the synchronous shift clock signal.

After writing the last frame of data, you must wait for the transmit buffer to be empty, that is, the SPI\_ISR.TXE flag becomes 1, and the SPI\_ISR.BUSY flag becomes 0 to ensure that the data is transmitted. Then set SPI\_SSI. SSI to 1, select the CS pin to output a high level in the slave, and end this communication.

#### Master receives

Set SPI\_CR1.MSTR to 1, SPI works in master mode; set SPI\_CR2.HDOE to 0, the master only receives data.

The master sets SPI\_SSI.SSI to 0, and the slave selects the CS pin to output a low level as the communication start signal.

When the transmit buffer is empty, that is, the SPI\_ISR.TXE flag is 1, write a frame of dummy data to the SPI\_DR register to start the transmission.

When the receive buffer is not empty, that is, the SPI\_ISR.RXNE flag is 1, indicating that a frame of data has been received, and the SPI\_DR register can be read at this time.

If you want to receive multiple frames of data, repeat the above steps to write to SPI\_DR and read the received data from SPI\_DR.

When all data frames are received, set SPI\_SSI.SSI to 1, select the CS pin to output a high level in the slave, and end this communication.

#### Slave transmits

Set SPI\_CR1.MSTR to 0, SPI works in slave mode; set SPI\_CR2.HDOE to 1, the slave only transmits data.

Before the slave select CS signal is pulled low, the slave needs to set SPI\_ICR.FLUSH to 0 to clear the transmit buffer and shift register, and write the first frame data to be transmitted into the SPI\_DR register.

When the CS signal is pulled low, the written data will be output from the MISO pin under the control of the master's synchronous shift clock signal.

If it is continuous communication of multiple data frames, the user should continuously query the SPI\_ISR.TXE flag bit. Once the flag is 1, immediately write the data to be transmitted into the SPI\_DR register to avoid data leakage.

This communication ends when it is detected that the CS pin changes to a high level.

#### Slave receives

Set SPI\_CR1.MSTR to 0, SPI works in slave mode; set SPI\_CR2.HDOE to 0, the slave only receives data.

When the CS pin is detected to go low, the slave starts to communicate with the master.

When the receive buffer is not empty, that is, the SPI\_ISR.RXNE flag becomes 1, indicating that a frame of data has been received, and the SPI\_DR register can be read at this time.

This communication ends when it is detected that the CS pin changes to a high level.

### 19.3.6 Simplex mode

SPI supports simplex communication mode, and the master and slave communicate with single transmitting or single receiving through a unidirectional data line.

The master uses the MOSI signal line for single transmitting communication, and the MISO signal line for single receiving communication; the slave uses the MOSI signal line for single receiving communication, and the MISO signal line for single transmitting communication, and the unused signal line can be used for other functions.

Set the MODE bit field of the control register SPI\_CR1 to 0x1, and the SPI works in the simplex single transmitting communication mode; set the MODE bit field to 0x2, and the SPI works in the simplex single receiving communication mode.

#### Caution:

In simplex single receiving mode, all events related to the receive stream on the transmitter side, such as the receive buffer overflow error flag bit SPI\_ISR.OV, must be ignored.



#### 19.3.6.1 Master single transmitting/slave single receiving

In the application scenario of single transmitting by the master and single receiving of the slave, the master and the slave use a MOSI data line to communicate. The application block diagram is shown in the following figure:

Figure 19-8 Master single transmitting, slave single receiving mode

### Master single transmitting

Set SPI\_CR1.MODE to 0x1, SPI works in simplex single transmitting communication mode; set SPI\_CR1.MSTR to 1, SPI works in master mode.

Set SPI\_SSI.SSI to 0, and select the CS pin to output a low level in the slave as the communication start signal.

When the transmit buffer is empty, that is, the SPI\_ISR.TXE flag bit is 1, a frame of data to be sent is written into the SPI\_DR register, and the data is output from the MOSI pin under the control of the synchronous shift clock signal.

After writing the last frame of data, you must wait for transmit buffer empty flag SPI\_ISR.TXE to become 1, and the SPI bus busy flag SPI\_ISR.BUSY to become 0 to ensure that the data is transmitted. Then set SPI\_SSI.SSI to 1, so that the slave selects the CS pin to output a high level, and ends this communication.

#### Slave single receiving

Set SPI\_CR1.MODE to 0x2, SPI works in simplex single receiving communication mode; set SPI\_CR1.MSTR to 0, SPI works in slave mode.

When the CS pin is detected to go low, the slave starts to communicate with the master.

When the receive buffer is not empty, that is, the SPI\_ISR.RXNE flag is 1, indicating that a frame of data has been received, and the SPI\_DR register can be read at this time.

This communication ends when it is detected that the CS pin changes to a high level.

#### 19.3.6.2 Master single receiving/slave single transmitting

In the application scenario of the master single receiving and the slave single transmitting, the master and the slave use a MISO data line to communicate. The application block diagram is shown in the following figure:

Shift register

MISO

MISO

Shift register

SCK

SCK

SCK

SCK

SCK

SCK

SCK

Slave

Figure 19-9 Master single receiving, slave single transmitting mode

### Master single receiving

Set SPI\_CR1.MODE to 0x2, SPI works in simplex single receiving communication mode; set SPI\_CR1.MSTR to 1, SPI works in master mode.

Set SPI\_SSI.SSI to 0, and select the CS pin to output a low level in the slave as the communication start signal.

When the transmit buffer is empty, that is, the SPI\_ISR.TXE flag is 1, write a frame of dummy data to the SPI\_DR register to start the transmission.

When the receive buffer is not empty, that is, the SPI\_ISR.RXNE flag is 1, indicating that a frame of data has been received, and the SPI\_DR register can be read at this time.

If you want to receive multiple frames of data, repeat the above steps to write to SPI\_DR and read the received data from SPI\_DR.

When all data frames are received, set SPI\_SSI.SSI to 1, and the slave selects the CS pin to output a high level to end this communication.

# Slave single transmitting

Set SPI\_CR1.MODE to 0x1, SPI works in simplex single transmitting communication mode; set SPI\_CR1.MSTR to 0, SPI works in slave mode.

Before the slave selection signal CS is pulled low, the slave needs to set SPI\_ICR.FLUSH to 0 to clear the transmit buffer and shift register, and write the first frame data to be transmitted into the SPI\_DR register.

When the CS signal is pulled low, the written data is output from the MISO pin under the control of the master's synchronous shift clock signal.

If it is continuous communication of multiple data frames, the user should continuously query the SPI\_ISR.TXE flag bit. Once the flag is 1, immediately write the data to be transmitted into the SPI\_DR register to avoid data leakage.

This communication ends when it is detected that the CS pin changes to a high level.



#### 19.3.7 Multi-machine communication

SPI supports multi-machine communication mode. In this mode, the slave select CS pin of the master should be configured as an input and connected to the bus application signal of other masters to detect whether there is a conflict on the SPI bus.

If the slave select CS pin of a master is pulled to a low level, it means that another master is occupying the bus, the master will generate a mode error (please refer to section 19.3.9 Error flags), the master SPI will be disabled, and the SPI will be disabled. Avoid SPI bus conflicts.

If the slave of a master selects the CS pin to detect a high level, it means that the SPI bus is idle. At this time, if the master wants to communicate with the slave, it must first apply for a signal on the bus to output a low level to other masters. CS signal, get SPI bus control, and then select a slave to start communication.

Figure 19-10 Multi-machine communication system shows a typical multi-machine communication system. Taking the communication between master A and slave 1 as an example, the operation process is as follows:

- Step 1: Master A detects the CS pin until a high level occurs;
- Step 2: GPIO0 of master A outputs a low level to obtain bus control, and master B is disabled;
- Step 3: GPIO1 of master A outputs low level, and slave 1 is selected;
- Step 4: The master A communicates with the slave 1;
- Step 5: GPIO1 of master A outputs a high level, releasing slave 1;
- Step 6: GPIO0 of master A outputs a high level, releasing the SPI bus.



Figure 19-10 Multi-machine communication system

In order to ensure the communication reliability in the multi-machine communication mode, the MISOHD bit field of the slave control register SPI\_CR1 should be set to 1. When the slave is selected, the MISO pin is CMOS output; when it is not selected, the MISO pin is high resistance output.

#### 19.3.8 Status flags

There are 6 status flags in the SPI controller to indicate the general working status of the SPI.

# Transmit buffer empty flag (SPI\_ISR.TXE)

When the transmit data is transferred from the SPI\_DR register to the shift register, the SPI\_ISR.TXE flag will be set by hardware, indicating that the transmit buffer is empty, and new data to be transmitted is allowed to be written to the SPI\_DR register. While writing data to the SPI\_DR register, the SPI\_ISR.TXE flag will be automatically cleared.

# Receive buffer not empty flag (SPI\_ISR.RXNE)

When the received data is transferred from the shift register to the SPI\_DR register, the SPI\_ISR.RXNE flag will be set by hardware, indicating that the reception of a frame of data has been completed. At this time, the SPI\_DR register can be read, and the SPI\_ISR will be cleared while reading the SPI\_DR register. RXNE flag bit.

Users can also manually clear the SPI\_ISR.RXNE flag by software.

# Bus busy flag bit (SPI\_ISR.BUSY)

The SPI\_ISR.BUSY flag bit, set and cleared by hardware, is used to indicate the current SPI communication status.

When preparing or performing data transmission (there is data in the transmit buffer or data in the shift register), the BUSY flag will be set by hardware, indicating that the SPI interface is in a busy state;

When there is no data transmission (no data in the send buffer and no data in the shift register), the BUSY flag is automatically cleared by hardware, indicating that the SPI interface is in an idle state.

# Slave select signal status (SPI\_ISR.SSLVL)

The SPI\_ISR.SSLVL status bit, set and cleared by hardware, indicates the level status of the slave select input signal.

SPI\_ISR.SSLVL is 0, the slave select CS input is low, and the slave is selected; SPI\_ISR.SSLVL is 1, the slave select CS input is high, and the slave is not selected.

### Slave select input rising edge flag (SPI\_ISR.SSR)

The SPI\_ISR.SSR flag bit is used to indicate whether the slave select CS input signal has a rising edge.

SPI\_ISR.SSR is 0, indicating that the slave select CS input has no rising edge; SPI\_ISR.SSR is 1, indicating that the slave select input has a rising edge.

#### Slave select input falling edge flag (SPI\_ISR.SSF)

The SPI\_ISR.SSF flag bit is used to indicate whether the slave select CS input signal has a falling edge.

SPI\_ISR.SSF is 0, indicating that the slave select CS input has no falling edge; SPI\_ISR.SSF is 1, indicating that the slave select CS input has a falling edge.



#### 19.3.9 Error flags

There are 4 error flags in the SPI controller to indicate whether an error has occurred in the SPI.

# Mode error flag (SPI\_ISR.MODF)

SPI\_ISR.MODF flag bit, used to detect bus conflict in SPI multi-machine communication mode.

When the SPI works in master mode and the slave select CS pin is configured as an input, if the CS pin input is low, a mode error will occur, and the SPI\_ISR.MODF flag is set by hardware, indicating that other SPI masters are occupying the bus at this time.

After a mode error occurs, SPI\_CR1.EN is cleared and the SPI is forced to shut down.

Setting SPI\_ICR.MODF to 0 can clear the SPI\_ISR.MODF flag. After clearing, the user needs to reconfigure the SPI controller.

After a mode error occurs, if the SPI controller is re-enabled, the SPI can still perform normal data transmission, but the SPI\_ISR.MODF flag will remain set until cleared by user software.

# Slave select error flag in slave mode (SPI\_ISR.SSERR)

When the SPI is working in slave mode and a valid data transfer is in progress, if the slave select CS input is pulled high, a slave select error will occur, and the SPI\_ISR.SSERR flag will be set by hardware.

The occurrence of a slave select error will cause an error in the current data transmission, and the slave will enter the unselected state.

After a slave select error occurs, if the slave select CS input is pulled low again, the SPI can still perform normal data transmission, but the SPI\_ISR.SSERR flag will remain set until cleared by user software.

## Receive buffer overflow error flag (SPI \_ISR.OV)

When the master or slave does not clear the SPI\_ISR.RXNE flag after receiving a frame of data, that is, neither read the SPI\_DR register nor clear the SPI\_ICR.RXNE to 0 by software, and and then when a new frame of data is received, a receive buffer overflow error will occur, and the SPI\_ISR.OV flag is set by hardware.

After a receive buffer overflow error occurs, the newly received data will overwrite the original data in the buffer.

After a receive buffer overflow error occurs, the SPI can still perform normal data transmission, but the SPI\_ISR.OV flag will remain set until cleared by user software.

#### Transmit buffer underflow error flag in slave mode (SPI\_ISR.UD)

When the SPI works in slave mode, if the transmit buffer is empty and the transmission of a new frame has already started, a transmit buffer underflow error will occur, and the SPI\_ISR.UD flag will be set by hardware, indicating that the slave did not send the data in time. The SPI\_DR register writes data and misses transmitting data to the host.

After the transmit buffer underflow error occurs, the SPI can still perform normal data transmission, but the SPI\_ISR.UD flag will remain set until cleared by user software.



# 19.4 SPI interrupts

The SPI controller supports 8 interrupt sources. When the SPI interrupt trigger event occurs, the interrupt flag bit will be set by hardware. If the corresponding interrupt enable control bit is set, an interrupt request will be generated.

An SPI module of CW32W031 uses a same system SPI interrupt, whether the SPI interrupt generates an interrupt jump is controlled by the corresponding bit of the interrupt enable setting register NVIC\_ISER. The schematic diagram of the system SPI interrupt is shown in the following figure:



Figure 19-11 SPI interrupts

In the user's SPI interrupt service routine, the relevant SPI interrupt flag bit should be queried for corresponding processing. Before exiting the interrupt service routine, the interrupt flag bit should be cleared to avoid repeatedly entering the interrupt routine.

The flag bit, interrupt enable bit, interrupt flag clear bit and clear method of each interrupt source of SPI are shown in the following table:

| Interrupt event                                | Interrupt flag bit | Interrupt enable bit | Flag clear method                               |  |
|------------------------------------------------|--------------------|----------------------|-------------------------------------------------|--|
| Transmit buffer empty                          | ISR.TXE            | IER.TXE              | Write SPI_DR register                           |  |
| Receive buffer not empty                       | ISR.RXNE IER.RXNE  |                      | Read SPI_DR register,<br>or write 0 to ICR.RXNE |  |
| Falling edge appears on the slave select input | ISR.SSF            | IER.SSF              | Write 0 to ICR.SSF                              |  |
| Rising edge appears on the slave select input  | ISR.SSR            | IER.SSR              | Write 0 to ICR.SSR                              |  |
| Transmit buffer underflow in slave mode        | ISR.UD             | IER.UD               | Write 0 to ICR.UD                               |  |
| Receive buffer overflow                        | ISR.OV             | IER.OV               | Write 0 to ICR.OV                               |  |
| Slave select error in slave mode               | ISR.SSERR          | IER.SSERR            | Write 0 to ICR.SSERR                            |  |
| Mode error                                     | ISR.MODF           | IER.MODF             | Write 0 to ICR.MODF                             |  |

Table 19-3 SPI interrupt control

407 / 572 Rev 1.0

# 19.5 Direct memory access (DMA)

The SPI controller supports the DMA transfer function to realize high-speed data transfer between the SPI data register and the memory without CPU intervention. DMA requests can be triggered by software or hardware, and DMA requests for transmit and receive are generated separately.

#### **DMA transmission**

Set SPI\_CR1.DMATX to 1 to enable SPI to send DMA transfer requests.

When the send buffer is empty, a DMA request is generated, triggering the DMA to transfer a frame of data from the specified storage area to the SPI\_DR register, until all the data configured in the DMA controller is transferred.

For the specific register configuration process of DMA transmission, please refer to chapter 8 *Direct memory access (DMA)* and section 19.6 *Programming examples*.

When the DMA transmission is completed, the corresponding DMA channel y transfer completion flag DMA\_ISR.TCy will be set by hardware. If the interrupt is enabled (that is, set DMA\_CSRy.TCIE to 1), an interrupt request will be generated.

In the user application, before closing the SPI, it is recommended to check whether the SPI\_ISR.BUSY flag has been cleared to ensure that all data has been sent through the SPI to avoid damaging the last transmitted data.

# **DMA** reception

Set SPI\_CR1.DMARX to 1 to enable SPI to receive DMA transfer requests.

When the receive buffer is not empty, a DMA request is generated, triggering the DMA to transfer data from the SPI\_DR register to the specified storage area, until all the data configured in the DMA controller is transferred.

For the specific register configuration process of DMA reception, please refer to chapter 8 *Direct memory access (DMA)* and section 19.6 *Programming examples*.

When the DMA transmission is completed, the corresponding DMA channel y transfer completion flag DMA\_ISR.TCy will be set by hardware. If the interrupt is enabled (that is, set DMA\_CSRy.TCIE to 1), an interrupt request will be generated.

# 19.6 Programming examples

## 19.6.1 Full duplex/master mode

# 19.6.1.1 Transmit and receive in query mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.SPI to 1, and enable the GPIO clock and SPI working clock corresponding to the SPI pin;
- Step 2: Configure the SPI\_SCK, SPI\_MOSI and SPI\_CS pins as push-pull multiplexed output mode, and configure the SPI\_MISO pin as floating input and multiplexed mode. For specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set SPI\_CR1.MODE to 0x0, and configure SPI to be bidirectional full-duplex communication mode;
- Step 4: Set SPI\_CR1.MSTR to 1, and configure SPI to master mode;
- Step 5: Configure SPI\_CR1.WIDTH and set the width of each frame of data;
- Step 6: Configure SPI\_CR1.LSBF and set the data bit sending and receiving sequence;
- Step 7: Configure SPI\_CR1.CPOL and set the clock polarity;
- Step 8: Configure SPI\_CR1.CPHA and set the clock phase;
- Step 9: Set SPI\_CR1.SSM to 1, and determine the slave select output value through the SSI register;
- Step 10: Configure SPI\_CR1.BR and set the SCK baud rate;
- Step 11: Set SPI\_CR1.EN to 1 to enable the SPI controller;
- Step 12: Set SPI\_SSI.SSI to 0, communication starts;
- Step 13: Query and wait for the SPI\_ISR.TXE flag to be set to 1, and confirm that the transmit buffer is empty;
- Step 14: Write a frame of data to be transmitted into the SPI\_DR register;
- Step 15: Query and wait for the SPI\_ISR.RXNE flag to be set to 1 to confirm that one frame of data has been received;
- Step 16: Read the SPI\_DR register and save the data;
- Step 17: Repeat steps 13~17 to send and receive the next frame of data until all data is transmitted and received;
- Step 18: Set SPI\_SSI.SSI to 1, communication ends.



#### 19.6.1.2 Transmit and receive in interrupt mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.SPI to 1, and enable the GPIO clock and SPI working clock corresponding to the SPI pin;
- Step 2: Configure the SPI\_SCK, SPI\_MOSI and SPI\_CS pins as push-pull multiplexed output mode, and configure the SPI\_MISO pin as floating input and multiplexed mode. For specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set SPI\_CR1.MODE to 0x0, and configure SPI to be bidirectional full-duplex communication mode;
- Step 4: Set SPI\_CR1.MSTR to 1, and configure SPI to master mode;
- Step 5: Configure SPI\_CR1.WIDTH and set the width of each frame of data;
- Step 6: Configure SPI\_CR1.LSBF and set the data bit sending and receiving sequence;
- Step 7: Configure SPI\_CR1.CPOL and set the clock polarity;
- **Step 8:** Configure SPI\_CR1.CPHA and set the clock phase;
- Step 9: Set SPI\_CR1.SSM to 1, and determine the slave selection output value through the SSI register;
- Step 10: Configure SPI\_CR1.BR and set the SCK baud rate;
- Step 11: Set SPI\_CR1.EN to 1 to enable the SPI controller;
- Step 12: Write 0x00 to SPI\_ICR to clear all flags;
- Step 13: Configure the NVIC controller, please refer to chapter 5 Interrupt;
- Step 14: Set SPI SSI.SSI to 0, communication starts;
- Step 15: Set SPI\_IER.RXNE to 1 to enable receive buffer non-empty interrupt;
- Step 16: Set SPI\_IER.TXE to 1 to enable transmit buffer empty interrupt;
- Step 17: Enter the interrupt service function: query and judge the SPI\_ISR.TXE flag bit, if the flag bit is 1, write a frame of data to be transmitted into the SPI\_DR register; query and judge the SPI\_ISR.RXNE flag bit, if the flag bit is 1, then read the SPI\_DR register and save the data;
- Step 18: Set SPI SSI.SSI to 1, communication ends.



#### 19.6.1.3 Transmit and receive in DMA mode

The following is a programming example of SPI (SPI\_CS pin is PA04, SPI\_SCK pin is PA05, SPI\_MISO pin is PA06, SPI\_MOSI pin is PA07) working in master mode, transmitting full-duplex mode data through DMA channel 1 and receiving full-duplex mode data through DMA channel 2.

In this application example, the PCLK is set to 24MHz, the baud rate is 6M bps, and the DMA data transmission amount is 100. The DMA transmission is started by hardware triggering, and the data in an 8-bit array SendBuff defined in the SRAM area is transferred to the transmit buffer. area, transfer the data in the receive buffer to an 8-bit array RecvBuff and save it.

- Step 1: Set SYSCTRL\_AHBEN.GPIOA to 1, SYSCTRL\_APBEN2.SPI to 1, SYSCTRL\_AHBEN.DMA to 1, enable the configuration clock and working clock of GPIOA, SPI and DMA respectively;
- Step 2: Configure the PA04, PA05 and PA07 pins as push-pull multiplexed output mode, and configure the PA06 pin as floating input and multiplexed mode. For specific register configuration steps. For specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set SPI\_CR1.MODE to 0x0, and configure SPI to be bidirectional full-duplex communication mode;
- Step 4: Set SPI\_CR1.MSTR to 1, and configure SPI to master mode;
- Step 5: Set SPI\_CR1.WIDTH to 0x7 and the data width to 8bit;
- Step 6: Set SPI\_CR1.LSBF to 0, the most significant bit is transmitted and received first;
- Step 7: Set SPI\_CR1.CPOL to 1, high level when the clock is idle;
- Step 8: Set SPI\_CR1.CPHA to 0, sample the front edge and shift the back edge;
- Step 9: Set SPI\_CR1.SSM to 1, and determine the slave select output value through the SSI register;
- Step 10: Set SPI\_CR1.BR to 0x1 and baud rate to 6M bps;
- Step 11: Set SPI\_CR1.EN to 1 to enable the SPI controller;
- Step 12: Define a variable uint8\_t SendBuff [100], and assign a value to store the data to be transmitted;
- Step 13: Define a variable uint8\_t RecvBuff [100] to store the data to be received;
- Step 14: Write 0x00 to SPI\_ICR to clear all flag bits of SPI;
- Step 15: Set DMA\_ICR.TC1, DMA\_ICR.TE1, DMA\_ICR.TC2, DMA\_ICR.TE2 to 0, clear all interrupt flags of DMA channel 1 and DMA channel 2;
- Step 16: Set DMA\_SRCADDR1= (uint32\_t) SendBuff, the source address is SendBuff;
- Step 17: Set DMA\_DSTADDR1= (uint32\_t) & SPI\_DR, the destination address is the SPI\_DR register;
- Step 18: Set DMA\_CSR1.SRCINC to 1, the source address is incremented automatically;
- Step 19: Set DMA\_CSR1.DSTINC to 0, the destination address is fixed;
- Step 20: Write 0x10064 to DMA\_CNT1, and the data transmission amount is 100;
- Step 21: Set DMA\_CSR1.SIZE to 0, and the transmission data bit width to 8bit;
- Step 22: Set DMA\_CSR1.TRANS to 1, block transmission (BLOCK);
- Step 23: Set DMA\_TRIG1. Type to 1, hardware trigger mode;
- Step 24: Set DMA\_TRIG1. HardSrc to 0x7, trigger DMA transmission when SPI transmit buffer is empty;
- Step 25: Set DMA\_SRCADDR2= (uint32\_t) & SPI\_DR, the source address is the SPI\_DR register;
- Step 26: Set DMA DSTADDR2=( uint32 t ) RecvBuff, the destination address is RecvBuff;
- Step 27: Set DMA\_CSR2.SRCINC to 0, the source address is fixed;
- Step 28: Set DMA CS2.DSTINC to 1, the destination address is incremented automatically;
- Step 29: Write 0x10064 to DMA\_CNT2, and the data transmission amount is 100;
- Step 30: Set DMA\_CSR2.SIZE to 0, and the transmission data bit width to 8bit;



- Step 31: Set DMA\_CSR2.TRANS to 1, block transmission (BLOCK);
- Step 32: Set DMA\_TRIG2. Type to 1, hardware trigger mode;
- Step 33: Set DMA\_TRIG2. HardSrc to 0x6, trigger DMA transmission when SPI receive buffer is not empty;
- Step 34: Set SPI\_SSI.SSI to 0, communication starts;
- Step 35: Set DMA\_CSR1.EN to 1 to enable DMA channel 1 transfer;
- Step 36: Set DMA\_CSR2.EN to 1 to enable DMA channel 2 transfer;
- Step 37: Set SPI\_CR1.DMATX to 1, and turn on the hardware handshake logic of SPI DMA transmission;
- Step 38: Set SPI\_CR1.DMATX to 1, and turn on the hardware handshake logic of SPI DMA reception;
- Step 39: Query and wait for DMA\_ISR.TC1 to become 1, and confirm that the transmission of DMA channel 1 is completed;
- Step 40: Query and wait for DMA\_ISR.TC2 to become 1, and confirm that the transmission of DMA channel 2 is completed;
- Step 41: Set SPI\_CR1.DMATX to 0, and turn off the hardware handshake logic of SPI DMA transmission;
- Step 42: Set SPI\_CR1.DMATX to 0, and turn off the hardware handshake logic of SPI DMA reception;
- Step 43: Query and wait for SPI\_ISR.BUSY to become 0 to ensure that the SPI bus is idle;
- Step 44: Set SPI\_SSI.SSI to 1, communication ends;
- Step 45: Repeat steps 14~45 if new data is to be transferred.

#### 19.6.2 Single-wire half-duplex/master mode

# 19.6.2.1 Transmit in query mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.SPI to 1, and enable the GPIO clock and SPI working clock corresponding to the SPI pin;
- Step 2: Configure the SPI\_SCK, SPI\_MOSI and SPI\_CS pins as push-pull multiplexed output mode. For specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set SPI\_CR1.MODE to 0x3, and configure SPI to be single-wire half-duplex communication mode;
- Step 4: Set SPI\_CR1.MSTR to 1, and configure SPI to master mode;
- Step 5: Configure SPI\_CR1.WIDTH and set the width of each frame of data;
- Step 6: Configure SPI\_CR1.LSBF and set the data bit transmitting and receiving sequence;
- Step 7: Configure SPI\_CR1.CPOL and set the clock polarity;
- **Step 8:** Configure SPI\_CR1.CPHA and set the clock phase;
- Step 9: Set SPI\_CR1.SSM to 1, and determine the slave select output value through the SSI register;
- Step 10: Configure SPI\_CR1.BR and set the SCK baud rate;
- Step 11: Set SPI\_CR1.EN to 1 to enable the SPI controller;
- Step 12: Set SPI\_SSI.SSI to 0, communication starts;
- Step 13: Set SPI\_CR2.HDOE to 1, only transmit;
- Step 14: Query and wait for the SPI\_ISR.TXE flag to be set to 1, and confirm that the transmit buffer is empty;
- Step 15: Write a frame of data to be transmitted into the SPI\_DR register;
- Step 16: If there is still data to be transmitted, repeat steps 14-16 to transmit the next frame of data;
- Step 17: Query and wait for the SPI\_ISR.TXE flag bit to be 1, and the last frame of data starts to be transmitted;
- Step 18: Query and wait for the SPI\_ISR.BUSY flag to become 0, and the SPI bus is idle;
- Step 19: Set SPI SSI.SSI to 1, communication ends.



#### 19.6.2.2 Receive in query mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.SPI to 1, and enable the GPIO clock and SPI working clock corresponding to the SPI pin;
- Step 2: Configure the SPI\_SCK, SPI\_MOSI and SPI\_CS pins as push-pull multiplexed output mode. For specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set SPI\_CR1.MODE to 11, and configure SPI to be single-wire half-duplex communication mode;
- Step 4: Set SPI\_CR1.MSTR to 1, and configure SPI to master mode;
- Step 5: Configure SPI\_CR1.WIDTH and set the width of each frame of data;
- Step 6: Configure SPI\_CR1.LSBF and set the data bit transmitting and receiving sequence;
- Step 7: Configure SPI\_CR1.CPOL and set the clock polarity;
- **Step 8:** Configure SPI\_CR1.CPHA and set the clock phase;
- Step 9: Set SPI\_CR1.SSM to 1, and determine the slave select output value through the SSI register;
- Step 10: Configure SPI\_CR1.BR and set the SCK baud rate;;
- Step 11: Set SPI\_CR1.EN to 1 to enable the SPI controller;
- Step 12: Set SPI\_SSI.SSI to 0, communication starts;
- Step 13: Set SPI\_CR2.HDOE to 0, only receive;
- Step 14: Query and wait for the SPI\_ISR.TXE flag to be set to 1, and confirm that the transmit buffer is empty;
- Step 15: Write a frame of dummy data into the SPI\_DR register;
- Step 16: Query and wait for the SPI\_ISR.RXNE flag to be set to 1 to confirm that one frame of data has been received;
- Step 17: Read the SPI\_DR register and save the data;
- Step 18: Repeat steps 14-18 to receive the next frame of data until all data is received;
- Step 19: Set SPI\_SSI.SSI to 1, communication ends.

#### 19.6.3 Simplex mode/master mode

#### 19.6.3.1 Transmit in query mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.SPI to 1, and enable the GPIO clock and SPI working clock corresponding to the SPI pin;
- Step 2: Configure the SPI\_SCK, SPI\_MOSI and SPI\_CS pins as push-pull multiplexed output mode. For specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set SPI\_CR1.MODE to 01, and configure SPI as simplex single-transmit communication mode;
- Step 4: Set SPI\_CR1.MSTR to 1, and configure SPI to master mode;
- Step 5: Configure SPI\_CR1.WIDTH and set the width of each frame of data;
- Step 6: Configure SPI\_CR1.LSBF and set the data bit transmitting and receiving sequence;
- Step 7: Configure SPI\_CR1.CPOL and set the clock polarity;
- **Step 8:** Configure SPI\_CR1.CPHA and set the clock phase;
- Step 9: Set SPI\_CR1.SSM to 1, and determine the slave select output value through the SSI register;
- Step 10: Configure SPI\_CR1.BR and set the SCK baud rate;
- Step 11: Set SPI\_CR1.EN to 1 to enable the SPI controller;
- Step 12: Set SPI\_SSI.SSI to 0,communication starts;
- Step 13: Query and wait for the SPI\_ISR.TXE flag to be set to 1, and confirm that the transmit buffer is empty;
- Step 14: Write a frame of data to be transmitted into the SPI\_DR register;
- Step 15: If there is still data to be transmitted, repeat steps 13-15 to transmit the next frame of data;
- Step 16: Query and wait for the SPI\_ISR.TXE flag bit to be 1, and the last frame of data starts to be transmitted;
- Step 17: Query and wait for the SPI\_ISR.BUSY flag to become 0, and the SPI bus is idle;
- Step 18: Set SPI\_SSI.SSI to 1, communication ends.



#### 19.6.3.2 Receive in query mode

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.SPI to 1, and enable the GPIO clock and SPI working clock corresponding to the SPI pin;
- Step 2: Configure the SPI\_SCK and SPI\_CS pins as push-pull multiplexing output mode, and configure the SPI\_MISO pin as floating input and multiplexing mode. For specific register configuration steps, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set SPI\_CR1.MODE to 10, and configure SPI as simplex single receiving communication mode;
- Step 4: Set SPI\_CR1.MSTR to 1, and configure SPI to master mode;
- Step 5: Configure SPI\_CR1.WIDTH and set the width of each frame of data;
- Step 6: Configure SPI\_CR1.LSBF and set the data bit transmitting and receiving sequence;
- Step 7: Configure SPI\_CR1.CPOL and set the clock polarity;
- Step 8: Configure SPI CR1.CPHA and set the clock phase;
- Step 9: Set SPI\_CR1.SSM to 1, and determine the slave select output value through the SSI register;
- Step 10: Configure SPI\_CR1.BR and set the SCK baud rate;
- Step 11: Set SPI\_CR1.EN to 1 to enable the SPI controller;
- Step 12: Set SPI\_SSI.SSI to 0, communication starts;
- Step 13: Query and wait for the SPI\_ISR.TXE flag to be set to 1, and confirm that the transmit buffer is empty;
- Step 14: Write a frame of dummy data into the SPI\_DR register;
- Step 15: Query and wait for the SPI\_ISR.RXNE flag to be set to 1 to confirm that one frame of data has been received;
- Step 16: Read the SPI\_DR register and save the data;
- Step 17: Repeat steps 13-17 to receive the next frame of data until all data is received;
- Step 18: Set SPI\_SSI.SSI to 1, communication ends.

# 19.7 List of registers

SPI base address: SPI\_BASE = 0x4001 3000

Table 19-4 List of SPI registers

| Register name | Register address | Register description          |
|---------------|------------------|-------------------------------|
| SPI_CR1       | SPI_BASE + 0x00  | Control register 1            |
| SPI_CR2       | SPI_BASE + 0x08  | Control register 2            |
| SPI_SSI       | SPI_BASE + 0x0C  | Slave select register         |
| SPI_IER       | SPI_BASE + 0x04  | Interrupt enable register     |
| SPI_ISR       | SPI_BASE + 0x10  | Interrupt flag register       |
| SPI_ICR       | SPI_BASE + 0x14  | Interrupt flag clear register |
| SPI_DR        | SPI_BASE + 0x18  | Data register                 |

# 19.8 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

# 19.8.1 SPI\_CR1 control register 1

Address offset: 0x00 Reset value: 0x0000 1C04

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|--------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19     | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                 |
| 18        | MISOHD | RW         | Slave MISO output configuration 0: MISO is always output for COMS 1: When the slave is selected, MISO is COMS output, and when it is not selected, it is high resistance output                                                                                                                                                                                                              |
| 17        | DMATX  | RW         | DMA transmit data enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                      |
| 16        | DMARX  | RW         | DMA receive data enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                       |
| 15:14     | MODE   | RW         | Communication mode configuration 00: bidirectional full duplex 01: simplex single transmitting 10: simplex single receiving 11: single-wire half-duplex                                                                                                                                                                                                                                      |
| 13:10     | WIDTH  | RW         | The width of each frame of data is WIDTH+1, for example 0011: 4bit 0100: 5bit 1110: 15bit 1111: 16bit                                                                                                                                                                                                                                                                                        |
| 9         | SSM    | RW         | Slave select configuration (Master mode) 0: The SPI_CS pin is in input mode, and the low level of the pin can select the machine 1: The SPI_CS pin is in output mode, and the output level comes from SSI Slave select configuration (slave mode) 0: SPI_CS pin level determines whether the machine is selected 1: The value of the SSI register determines whether the machine is selected |

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                 |
|-----------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8         | SMP  | RW         | Master mode delayed sampling 0: In the traditional way of SPI, the data received by the master is sampled according to the settings of CPOL and CPHA 1: Delayed sampling method, the sampling time is delayed by half SCK cycle compared with the traditional method |
| 7         | LSBF | RW         | Data frame high and low sequence selection 0: Most significant bit MSB is sent and received first 1: Least significant bit MSB is sent and received first                                                                                                            |
| 6         | EN   | RW         | Enable control 0: SPI module disabled 1: SPI module enabled                                                                                                                                                                                                          |
| 5:3       | BR   | RW         | Master mode SCK baud rate configuration 000: PCLK/2 001: PCLK/4 010: PCLK/8 011: PCLK/16 100: PCLK/32 101: PCLK/64 110: PCLK/128 111: Reserved                                                                                                                       |
| 2         | MSTR | RW         | Work mode configuration 0: slave mode 1: master mode                                                                                                                                                                                                                 |
| 1         | CPOL | RW         | Serial clock polarity configuration 0: Low level in standby 1: High level in standby                                                                                                                                                                                 |
| 0         | СРНА | RW         | Serial clock phase configuration 0: Leading edge sampling/trailing edge shift 1: Leading edge shift/trailing edge sampling                                                                                                                                           |

# 19.8.2 SPI\_CR2 control register 2

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                        |
|-----------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                |
| 0         | HDOE | RW         | When single-wire half-duplex, data transmission/reception status control 0: Only received 1: Only transmitted Caution: Only valid for single-wire half-duplex communication |

# 19.8.3 SPI\_SSI slave select register

Address offset: 0x0C Reset value: 0x0000 0001

| Bit field | Name  | Permission | Function description                         |               |          |                         |                                      |    |   |          |         |
|-----------|-------|------------|----------------------------------------------|---------------|----------|-------------------------|--------------------------------------|----|---|----------|---------|
| 31:1      | RFU   | -          | Reserved bits, please keep the default value |               |          |                         |                                      |    |   |          |         |
|           |       |            | Slave sel                                    | ect, valid wh | en SPI_C | R1.SSM is 1             |                                      |    |   |          |         |
|           |       |            | SSM                                          | MSTR          | SSI      | Description             |                                      |    |   |          |         |
|           | 0 SSI | RW 1       | RW                                           | RW            | RW       | RW                      | RW                                   | 0  | - | -        | Invalid |
| 0         |       |            |                                              |               |          |                         |                                      | RW |   | 0(slave) | 0       |
|           |       |            |                                              | 1             | U(Stave) | 1                       | Set this machine to unselected state |    |   |          |         |
|           |       |            |                                              | 1(master)     | 0        | SPI_CS pins output low  |                                      |    |   |          |         |
|           |       |            |                                              |               | 1        | SPI_CS pins output high |                                      |    |   |          |         |

# 19.8.4 SPI\_IER interrupt enable register

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                                          |
|-----------|-------|------------|-----------------------------------------------------------------------------------------------|
| 31:8      | RFU   | -          | Reserved bits, please keep the default value                                                  |
| 7         | MODF  | RW         | Mode error interrupt enable control 0: Disabled 1: Enabled                                    |
| 6         | SSERR | RW         | Slave select error interrupt enable control in slave mode 0: Disabled 1: Enabled              |
| 5         | OV    | RW         | Receive buffer overflow error interrupt enable control 0: Disabled 1: Enabled                 |
| 4         | UD    | RW         | Transmit buffer underflow error interrupt enable control in slave mode 0: Disabled 1: Enabled |
| 3         | SSR   | RW         | Slave select input rising edge interrupt enable control 0: Disabled 1: Enabled                |
| 2         | SSF   | RW         | Slave select input falling edge interrupt enable control 0: Disabled 1: Enabled               |
| 1         | RXNE  | RW         | Receive buffer non-empty interrupt enable control 0: Disabled 1: Enabled                      |
| 0         | TXE   | RW         | Transmit buffer empty interrupt enable control 0: Disabled 1: Enabled                         |

# 19.8.5 SPI\_ISR interrupt flag register

Address offset: 0x10 Reset value: 0x0000 0001

| Bit field | Name  | Permission | Function description                                                                                                                                                              |
|-----------|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10     | RFU   | -          | Reserved bits, please keep the default value                                                                                                                                      |
| 9         | SSLVL | RO         | Slave select signal state 0: Slave select signal is low level 1: Slave select signal is high level                                                                                |
| 8         | BUSY  | RO         | Bus busy flag 0: Bus idle 1: Bus busy                                                                                                                                             |
| 7         | MODF  | RO         | Mode error flag 0: Normal 1: Error Caution: In master mode, the slave select input is low to trigger MODF                                                                         |
| 6         | SSERR | RO         | Slave select error flag in slave mode 0: Normal 1: Error                                                                                                                          |
| 5         | OV    | RO         | Receive buffer overflow error flag bit 0: Normal 1: Error                                                                                                                         |
| 4         | UD    | RO         | Transmit buffer underflow error flag in slave mode 0: Normal 1: Error                                                                                                             |
| 3         | SSR   | RO         | Slave select input rising edge flag bit 0: No rising edge occurred 1: Rising edge has occurred                                                                                    |
| 2         | SSF   | RO         | Slave select input falling edge flag bit 0: No falling edge occurred 1: Falling edge occurred                                                                                     |
| 1         | RXNE  | RO         | Receive buffer not empty flag bit 0: Receive buffer is empty 1: Receive buffer is not empty Caution: This flag can be cleared by reading the DR register or writing 0 to ICR.RXNE |
| 0         | TXE   | RO         | Send buffer empty flag bit 0: Send buffer is not empty 1: Send buffer is empty                                                                                                    |

# 19.8.6 SPI\_ICR interrupt flag clear register

Address offset: 0x14 Reset value: 0x0000 00FF

| Bit field | Name  | Permission | Function description                                                                                                                             |
|-----------|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8      | RFU   |            | Reserved bits, please keep the default value                                                                                                     |
| 7         | MODF  | R1W0       | Mode error flag cleared<br>W0: Mode error flag cleared<br>W1: No function                                                                        |
| 6         | SSERR | R1W0       | Slave select error flag cleared in slave mode<br>W0: Slave select error flag in slave mode cleared<br>W1: No function                            |
| 5         | OV    | R1W0       | Receive buffer overflow error flag cleared<br>W0: Receive buffer overflow error flag cleared<br>W1: No function                                  |
| 4         | UD    | R1W0       | Transmit buffer underflow error flag cleared in slave mode W0: Transmit buffer underflow error flag in slave mode cleared W1: No function        |
| 3         | SSR   | R1W0       | Slave select input rising edge flag cleared<br>W0: Slave select input rising edge flag cleared<br>W1: No function                                |
| 2         | SSF   | R1W0       | Slave select input falling edge flag cleared<br>W0: Slave select input falling edge flag cleared<br>W1: No function                              |
| 1         | RXNE  | R1W0       | Receive buffer not empty flag cleared<br>W0: Receive buffer not empty flag cleared<br>W1: No function                                            |
| 0         | FLUSH | R1W0       | Clear transmit buffer and shift register W0: The transmit buffer and shift register (ISR.TXE is set to 1 after clearing) cleared W1: No function |

# 19.8.7 SPI\_DR data register

Address offset: 0x18 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                  |
|-----------|------|------------|-------------------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value          |
| 15:0      | DR   | RW         | Write data to be transmitted<br>Read as received data |



# 20 I2C interface

#### 20.1 Overview

CW32W031 integrates one I2C controllers, which can serially transmit the data to be transmitted to the I2C bus according to the I2C specification according to the set transmission rate (standard, fast, high-speed), and detect the state during the communication process. Bus collision and arbitration handling in multi-master communication is also supported.

### 20.2 Main features

- Supports master transmit/receive and slave transmit/receive four working modes
- Supports clock stretching (clock synchronization) and multi-master communication conflict arbitration
- Supports standard (100Kbps)/fast (400Kbps)/high speed (1Mbps) three working rates
- Supports 7bit addressing function
- Supports 3 slave addresses
- Supports broadcast address
- Supports input signal noise filtering function
- Supports interrupt status query function



# 20.3 Protocol description

The I2C bus uses two signal lines (the data line SDA and the clock line SCL) to transfer data between devices. SCL is a unidirectional clock line, which is fixedly driven by the master. SDA is a bidirectional data line, which is driven by the transmitting and receiving terminals in time sharing during data transmission.

Multiple devices can be connected to the I2C bus. All devices are in an idle state when they are not transmitting data (the slave receiving mode is not addressed). Any device can send a START signal as a master to start data transmission. The bus is occupied until the STOP signal appears on the bus.

I2C communication adopts the master-slave structure, and the communication is initiated and terminated by the master. The master initiates communication by transmitting the START signal, then transmits a total of 8 bits of SLA+W/R data (where SLA is the 7-bit slave address, and W/R is the read-write bit), and releases the SDA bus at the ninth SCL clock, the corresponding slave occupies the SDA bus at the ninth SCL clock and outputs an ACK response signal to complete the slave addressing. After that, the transmitter and receiver of data communication are determined according to the W/R bit of the first byte transmitted by the master. For each byte of data transmitted by the transmitter, the receiver must respond with an ACK response signal. After the data transmission is completed, the master transmits a STOP signal to end the communication.

#### 20.3.1 Protocol frame format

The standard I2C transmission protocol frame consists of four parts: start signal (START) or repeated start signal (Repeated START), slave address and read and write bits, data transmission, and stop signal (STOP). As shown in the following figure:



Figure 20-1 I2C protocol frame

#### Start signal (START)

When the bus is in an idle state (SCL and SDA lines are high at the same time), a falling edge signal from high to low appears on the SDA line, which is defined as a start signal. After the master transmits a start signal to the bus, data transmission starts and the bus is occupied.

Repeated start signal (Repeated START)

When a start signal does not appear before a stop signal, a new start signal appears, and the new start signal is defined as a repeated start signal. Before the master transmits the stop signal, the SDA bus is always in the occupied state, and other masters cannot occupy the bus.



## Stop signal (STOP)

When the SCL line is high, a rising edge signal from low to high appears on the SDA line, which is defined as a stop signal. The master transmits a stop signal to the bus to end the data transfer and releases the bus.



Figure 20-2 Start and stop signals

#### Slave address and read/write bit

When the start signal is generated, the master starts to transmit the first byte of data: 7 bit slave address + read and write bits. The read and write bits (1: read; 0: write) control the direction of data transfer on the bus. The addressed slave occupies the SDA bus during the 9th SCL clock cycle and acknowledges the ACK by asserting SDA low.

#### Data transmission

The master outputs the serial clock signal on the SCL line, and the master and slave devices transmit data through the SDA line. During data transmission, 1 SCL clock pulse transmits 1 data bit (the most significant bit MSB is first), and the data on the SDA line changes only when SCL is low, and each transmitted 1 byte is followed by an acknowledge bit. As shown in the following figure:



Figure 20-3 Data transmission

#### 20.3.2 Transmission response

When transmitting data on the bus, the transmitter gives up the control of SDA in the 9th SCL clock cycle after transmitting 1 byte of data, and the receiver must reply a response bit in the 9th SCL clock cycle: the reception is successful, Send ACK response, receive exception send NACK response.



Figure 20-4 Transmission response

#### 20.3.3 Conflict detection and arbitration

In a multi-master communication system, each node on the bus has a slave address. Each node can be accessed by other nodes as a slave node, and can also be used as a master node to send control bytes and transmit data to other nodes. A bus collision occurs when two or more nodes send a start signal to the bus at the same time and start transmitting data. The I2C controller has a built-in arbiter that can detect and arbitrate I2C bus conflicts to ensure the reliability and integrity of data communication.

# Conflict detection principle

In the physical realization, the SDA and SCL pins have the same circuit structure, and the output drive of the pin is connected with the input buffer. The output structure is an open-drain field effect transistor, and the input structure is an inverter with high input impedance. Based on this structure:

- 1. Since SDA and SCL are open-drain structures, the "wire-and" logic of the signal is realized by means of an external pull-up resistor;
- 2. The device reads data while writing data to the bus, which can be used to detect bus conflicts and realize "clock synchronization" and "bus arbitration".

According to the "wire-and" logic, if two masters send logic 1 or logic 0 at the same time, neither of the two masters can detect the conflict, and it needs to wait until the next bit of data is transmitted before continuing to detect the conflict; if one of the two hosts sends a logic 1, When a logic 0 is transmitted, the bus is logic 0 at this time, the master transmitting logic 1 detects a conflict, and the master transmitting logic 0 does not detect a conflict.



#### Conflict arbitration principles

When the master detects a bus conflict, the master loses arbitration, exits the master transmit mode, enters the unaddressed slave mode, releases the SDA data line, and returns to the address detection state, and then enters the state according to the received SLA+W/R corresponding slave mode (SLA address match enters addressed slave mode, SLA address mismatch enters unaddressed slave mode). The master that loses arbitration will still send the SCL serial clock until the end of the current byte transfer.

When the master does not detect a bus conflict, the master wins the arbitration and continues to dominate the data transfer until the communication is complete.

The following figure is a schematic diagram of transmitting conflict and arbitration between master A and master B on an I2C bus (assuming that the transmitting clocks of the two masters A and B are synchronized):



Figure 20-5 Conflict detection and arbitration

- 1. In stage (1), both master A and master B transmit logic 1 and logic 0 successively. Since the data is the same and synchronous, neither host will detect a bus conflict.
- 2. In stage (2), master A transmits a logic 1, master B transmits a logic 0, and the data on the SDA bus is a logic 0. The A host controller detects a data error and exits the transmission competition, that is, the arbitration is lost, and the A master enters the unaddressed slave receiver mode. Host B does not detect a bus conflict, wins the arbitration, and continues this data transfer.
- 3. In phase (3), the A master is in unaddressed slave receive mode, but still generates SCL clock pulses until the end of the current byte transfer. After that, the A host I2C controller no longer transmits the clock signal. Since the B master wins the arbitration, both SCL and SDA are dominated by the B master to control the transfer.

# 20.4 Functional description

# 20.4.1 Functional block diagram

The I2C module mainly includes clock generator, input filter, address comparator, protocol control logic, arbitration and synchronization logic, and related registers. Its functional block diagram is shown in the following figure:



Figure 20-6 I2C functional block diagram

CW32W031 supports users to flexibly select GPIO as I2C communication pin, as shown in the following table:

Table 20-1 I2C pin selection

| I2C     | Pin                                |  |
|---------|------------------------------------|--|
| I2C_SCL | PA09/PA14/PB08/PB10/PF01/PF06      |  |
| I2C_SDA | PA10/PA13/PB07/PB09/PB11/PF00/PF07 |  |

## 20.4.2 Serial clock generator

The serial clock generator is used to generate the baud rate clock SCL for I2C communication. The serial clock generator uses PCLK as the input clock, counts through an 8-bit counter, and outputs the I2C clock signal with the required baud rate.

SCL clock frequency calculation formula:

$$f_{SCL} = f_{PCLK} / 8 / (BRR + 1)$$

Where, BRR is configured through the baud rate counter configuration register I2C\_BRR, and the effective range of BRR is 1~255.

The counter count of the serial clock generator is enabled by the EN bit field of the I2C\_BRREN register. EN is 1 to enable and 0 to prohibit. When the master is used, EN should be set to 1, and this bit has no effect when the slave is used.

The corresponding relationship between the combination of PCLK and BRR and the SCL clock frequency is shown in the following table:

Table 20-2 I2C transfer rate and configuration example

| f <sub>scl</sub> (kHz)  |      | I2C_BRR |     |     |     |     |     |
|-------------------------|------|---------|-----|-----|-----|-----|-----|
| f <sub>PCLK</sub> (kHz) | 1    | 2       | 3   | 4   | 5   | 6   | 7   |
| 1000                    | 62   | 41      | 31  | 25  | 20  | 17  | 15  |
| 2000                    | 125  | 83      | 62  | 50  | 41  | 35  | 31  |
| 4000                    | 250  | 166     | 125 | 100 | 83  | 71  | 62  |
| 6000                    | 375  | 250     | 187 | 150 | 124 | 107 | 93  |
| 8000                    | 500  | 333     | 250 | 200 | 166 | 142 | 125 |
| 10000                   | 625  | 416     | 312 | 250 | 208 | 178 | 156 |
| 12000                   | 750  | 500     | 375 | 300 | 250 | 214 | 187 |
| 14000                   | 875  | 583     | 437 | 350 | 291 | 250 | 218 |
| 16000                   | 1000 | 666     | 500 | 400 | 333 | 285 | 250 |



#### 20.4.3 Input filter

The input filter can filter the SDA and SCL input signals, and the spike signal less than 1 PCLK cycle will be filtered out.

The input filter can be configured in two modes: simple filter mode and advanced filter mode. Simple filtering has faster communication rate; advanced mode has higher anti-jamming performance. The filtering mode is configured through the FLT bit field of the I2C control register I2C\_CR. Setting I2C\_CR.FLT to 1 is the simple filtering mode, and setting I2C\_CR.FLT to 0 is the advanced filtering mode.

As a master, if the value of BRR is less than or equal to 9, I2C\_CR.FLT should be set to 1; if the value of BRR is greater than 9, then I2C\_CR.FLT should be set to 0.

As a slave, if the frequency ratio of PCLK to SCL is less than or equal to 40, then I2C\_CR.FLT should be set to 1; if the frequency ratio of PCLK to SCL is greater than 40, then I2C\_CR.FLT should be set to 0.

# 20.4.4 Address comparator

Each device on the I2C bus has a slave address, and each slave address is different. The master addresses the slave according to the slave address, and the slave automatically detects whether the 7bit addressing address transmitted by the master matches the local address through the address comparator to determine whether to communicate with the master.

The I2C controller supports 3 programmable slave addresses, and the specific address information is configured through the slave address registers I2C\_ADDR0/I2C\_ADDR1/I2C\_ADDR2.

The address comparator of the slave machine compares the received 7-bit addressing address with the three slave addresses and the broadcast address (0x00). If it matches any one of the 4 addresses, it is considered that the address matches, and the I2C interrupt flag bit I2C\_CR.SI will be set to 1, and an interrupt request will be generated. The application program can obtain the successfully matched address serial number by querying the slave address matching register I2C\_MATCH.

If the address matches I2C\_ADD0/1/2, the slave enters the corresponding addressed slave receive mode (receives SLA+W) or addressed slave transmit mode (receives SLA+R); if the address matches to If the broadcast address is 0x00 (SLA+W is received), the slave enters the broadcast receiving mode.



431 / 572 Rev 1.0

### 20.4.5 Arbitration and synchronization logic

### 20.4.5.1 SCL synchronization

I2C supports clock synchronization (clock stretching) function, the time of SCL clock low level is determined by the device with the longest SCL clock low level width, and the SCL clock high level time is determined by the device with the shortest clock high level width.

If the slave wants the master to reduce the transmission speed, it can keep I2C\_CR.SI 1 after receiving the data and responding to ACK, and the slave I2C controller will keep SCL low to notify the master. When the master is ready for the next byte data transfer (transmit or receive), it detects that the level of SCL is pulled low, and waits until the slave completes the operation and clears I2C\_CR.SI to 0, and the slave controller releases the pull of SCL. Low control, the master continues to transmit the next byte of data after detecting that SCL is high.

#### 20.4.5.2 SDA arbitration

I2C supports SDA conflict detection and arbitration, which can ensure that the data on the I2C bus is not destroyed when multiple masters attempt to control the I2C bus.

When each master transmits data, it will simultaneously compare whether the data on the bus is consistent with the data transmitted by itself. If they are inconsistent, it is considered that a bus conflict is detected, and the transmitting competition will be withdrawn, that is, the arbitration will be lost. A master that loses arbitration will immediately switch to an unaddressed slave state to ensure that it can be addressed by a master that succeeds in arbitration. A master that loses arbitration continues to output the SCL serial clock until the current byte transfer is complete.

SDA arbitration generally occurs when the master transmits SLA+W/R data. If two masters transmit data to a slave at the same time, that is, the slave addresses transmitted by the two masters are the same, the arbitration will continue in the second byte.



432 / 572 Rev 1.0

### 20.4.6 Response control

The receiver of the I2C data transmission must give an ACK or NACK response to the transmitter in the 9th SCL clock cycle of each byte. The receiver obtains the current state of the receiver through the response bit: responding with an ACK response means that the receiver has received it correctly. This byte of data can continue to receive the next byte of data; responding to NACK generally indicates that the receiver no longer receives any data.

Whether the receiver sends ACK or NACK is controlled by the AA bit field of the receiver's I2C control register I2C\_CR. When I2C\_CR.AA is set to 1, the I2C module will respond with an ACK response every time it receives 1 byte of data. When I2C\_CR.AA is set to 0, the I2C module will respond with a NACK response every time it receives 1 byte of data.

In the process of receiving data by the master, the master as the initiator of communication, controls the number of bytes transmitted and received. The master (receiver) responds to the NACK response to the slave (transmitter) after receiving the last byte of data, and the slave receives the NACK. After the slave receives the NACK response, it will switch to unaddressed slave receive mode and release the SDA bus so that the master can transmit a STOP signal or a Repeated START signal.

In the process of transmitting data from the slave, if its own I2C\_CR.AA response control bit is cleared by the application program, the slave will switch itself to the unaddressed slave receiving mode after transmitting the last 1 byte of valid data, and release the SDA bus, the master will get 0xFF when reading data from the bus. At this time, the master should be able to judge that the slave is in an unresponsive state, and send a STOP signal or a Repeated START signal.

In the process of receiving data from the slave, if it responds to NACK to the master (transmitter), it means that the slave (receiver) actively ends the communication, no longer receives the data transmits by the master, and switches itself to the unaddressed slave to receive mode, and release the SDA bus, at this time the master should send a STOP signal or a Repeated START signal.

#### 20.4.7 I2C interrupts

The SI bit field of the I2C control register I2C\_CR is the interrupt flag bit. When the value of the STAT bit field of the I2C status register I2C\_STAT changes (except for 0xF8), the I2C\_CR.SI flag will be set and an interrupt request will be generated.

In the user I2C interrupt service routine, you should query the STAT bit field value of the I2C status register I2C\_STAT to obtain the status of the I2C bus to determine the cause of the interrupt. Set I2C\_CR.SI to 0 to clear this flag.



### 20.4.8 Operating modes

The I2C controller supports 4 operating modes: master transmit mode, master receive mode, slave transmit mode, and slave receive mode. In addition, the broadcast receive mode is also supported, and its working method is similar to that of the slave receive mode.

#### 20.4.8.1 Master transmit mode

In master transmit mode, the master actively transmits multiple bytes to the slave.

The SCL serial clock is controlled by the master, so it is necessary to set the I2C\_BRR register according to the transmission baud rate and set the EN bit field of the I2C\_BRREN register to 1, and then start the transmission.

The master sets I2C\_CR.STA to 1, and informs the controller to transmit a START signal. After the controller receives the notification, it detects whether the bus is free. When the bus is free, the master controller transmits a START signal to the bus. If the transmission is successful, the status code I2C\_STAT becomes 0x08, and the interrupt flag bit I2C\_CR.SI is set to 1.

After the master transmits the START signal, software needs to set I2C\_CR.STA to 0, and then write the slave address and write flag bit (SLA+W) to the I2C data register I2C\_DR; clear the I2C\_CR.SI bit, the master controller SLA+W will be transmitted to the I2C bus; when the master transmits SLA+W and receives the ACK response signal from the slave, the status code I2C\_STAT becomes 0x18, and the interrupt flag bit I2C\_CR.SI is set to 1.

After that, the master transmits multiple bytes of user-defined data and detects the ACK response signal according to the needs of the application. The transmitting process of each byte is similar to that of sending SLA+W data frames.

In the process of transmitting data, if the master receives a NACK response signal, it indicates that the slave no longer receives the data sent by the host (I2C\_CR.AA of the slave is cleared), the master should send a STOP signal to end the data transfer, or send Repeated START repeats the start signal to start a new round of transmission.

When the master completes transmitting all the data, set I2C\_CR.STO to 1 to notify the controller that the data has been transmitted and the STOP signal is to be transmitted. Clear the I2C\_CR.SI bit, and the master controller will transmit a STOP signal to the I2C bus to complete this data transfer and release the bus.

When the master has finished transmitting all the data, it can also not transmit the STOP signal, but directly transmit the Repeated START signal, and continue to occupy the bus for a new round of data transmission.

When the master loses arbitration due to a bus conflict, it enters the unaddressed slave receive mode (status code I2C\_STAT=0x38).

The state synchronization diagram in the master transmit mode is shown in the following figure:



434 / 572 Rev 1.0

8 9 SCL S SDA CR.SI Bus status 0xF8 0x08 0xF8 0x18 0xF8 0x28 0xF8 Clear the SI bit Clear the SI bit Clear the SI bit

Figure 20-7 The status synchronization diagram of master transmit mode

The data transmission flow chart and status register values in the master transmit mode are shown in the following figure:





Figure 20-8 Master transmit mode flow and register status



#### 20.4.8.2 Master receive mode

The master receive mode is used to receive multiple data transmitted by the slave, and the master will respond with an ACK response signal every time it receives 1 byte of data.

The SCL serial clock is controlled and generated by the master, so it is necessary to set the I2C\_BRR register of the master according to the transmission baud rate and set the EN bit field of the I2C\_BRREN register to 1, and then start the transmission.

The master sets I2C\_CR.STA to 1, and informs the controller to send a START signal. After the controller receives the notification, it detects whether the bus is free. When the bus is free, the master controller sends a START signal to the bus. If the transmission is successful, the status code I2C\_STAT becomes 0x08, and the interrupt flag bit I2C\_CR.SI is set to 1.

After the master sends the START signal, the software needs to set I2C\_CR.STA to 0, and then write the slave address and read flag bit (SLA+R) to the I2C data register I2C\_DR; clear the I2C\_CR.SI flag bit, the master controls the controller will send SLA+R to the I2C bus; when the master sends SLA+R and receives the ACK response signal from the slave, the status code I2C\_STAT becomes 0x40, and the interrupt flag bit I2C\_CR.SI is set to 1.

After that, the master sets I2C\_CR.AA to 1, clears the I2C\_CR.SI bit, and starts to receive the data transmitted by the slave. After receiving 1 byte of data, it will reply an ACK response signal. During the master receiving process, it should be cautiond that:

- 1. In order to ensure that the I2C\_CR.SI interrupt signal can be correctly generated after receiving 1 byte of data, it is necessary to clear the I2C\_CR.SI bit in time after receiving 1 byte of data.
- 2. Before receiving the last byte, I2C\_CR.AA needs to be cleared, that is, the master does not generate an ACK response signal when receiving the last byte, so as to notify the slave to stop data transmission.

In the process of receiving data by the master, if the slave no longer transmits the data required by the master for some reason (the I2C\_CR.AA of the slave is cleared), the master will receive all 1 signals later. At this time, the master needs to be in the application layer. Judgment is made on the data, and it is determined that the slave is in an unresponsive state. It should send a STOP signal to end the current transmission, or send a Repeated START signal to start a new round of transmission.

When the master completes receiving all the data, set I2C\_CR.STO to 1 to notify the controller that the data has been received and to send a STOP signal. Clear the I2C\_CR.SI bit, and the master controller sends a STOP signal to the I2C bus to complete the data transfer and release the bus.

When the master has finished receiving all the data, it can also not send the STOP signal, but directly send the Repeated START signal, and continue to occupy the bus for a new round of data transmission.

When the master loses arbitration due to a bus conflict, it enters the unaddressed slave receive mode (status code I2C\_STAT=0x38).

The state synchronization diagram in the master receive mode is shown in the following figure:



437 / 572 Rev 1.0

CR.AA SCL Р SDA CR.SI 0xF8 0x08 0xF8 0xF8 0x50 0xF8 Bus status 0x40 0x58 0xF8 Clear the SI bit Clear the SI bit Clear the SI bit Clear the SI bit

Figure 20-9 The status synchronization diagram of master receive mode

The data reception flow chart and status register value in the master receive mode are shown in the following figure:



Figure 20-10 Master receive mode flow and register status

#### 20.4.8.3 Slave receive mode

In slave receive mode, the slave receives the data transmitted by the master.

Before transmission, the slave needs to set the slave address: write the slave address to any one of the three slave address registers I2C\_ADDR0, I2C\_ADDR1, I2C\_ADDR2; set I2C\_CR.AA to 1 to respond to the master's addressing; I2C\_BRR The set value of the register is invalid, so it is not necessary to set it.

After completing the above initialization work, the slave machine enters the idle state (the slave receiving mode is not addressed), waiting to be addressed by the write signal (SLA+W) sent by the master. After the slave receives SLA+W, if the address matches I2C\_ADDR0/1/2, the slave responds with ACK and enters the addressed slave receiving mode, the status code I2C\_STAT becomes 0x60, and the interrupt flag bit I2C\_CR.SI Also set to 1. The I2C\_CR.SI bit must be cleared at this time in order to receive data from the master from the bus.

Every time the slave receives 1 byte of data, it must respond with an ACK response. After the application reads the byte of data, it must clear the I2C\_CR.SI bit to prepare for receiving the next byte of data.

In the process of receiving data from the slave, if I2C\_CR.AA is cleared, the slave will return a NACK signal when it receives the next byte, and the state of the slave will also switch to the unaddressed slave receiving mode, ending with the master. communication, no more data is received, and the I2C\_DR register holds the previously received data. It can be seen from this feature that the slave application can actively switch the slave from the addressed slave receive mode to the unaddressed slave receive mode by setting I2C\_CR.AA to 0.

When the master loses arbitration due to bus conflict in the SLA+ read and write stage, it will enter the unaddressed slave receiving mode, and then if it receives SLA+W that matches the local address and responds with ACK (status code I2C\_STAT=0x68), it will enter addressed slave receive mode.

The state synchronization diagram in slave receive mode is shown in the following figure:



Figure 20-11 The status synchronization diagram of slave receive mode

The data receive flow chart and status register value in slave receive mode are shown in the following figure:



439 / 572 Rev 1.0

(STA,STO,SI,AA)=(0,0,0,1), write AA=1, Enable ACK response 12C STAT = 0x60 SLA+W received, and ACK returned I2C\_STAT = 0x68 Master lost arbitration transfer in SLA+W received, and ACK returned (STA,STO,SI,AA)=(X,0,0,1), write AA=1, write SI=0  $(STA,STO,SI,AA) = (X,0,0,X)\,,$  write SI=0, waiting to receive repeated START or STOP signals (STA,STO,SI,AA)=(X,0,0,0), write AA=0, write SI=0 Waiting to receive 1 byte of data Waiting to receive 1 byte of data I2C\_STAT = 0x80 I2C\_STAT = 0x88 I2C\_STAT = 0xA0 1 byte of data has been received, and ACK has been returned 1 byte of data has been received, and NACK has been returned received repeated START or STOP signals (STA,STO,SI,AA)=(1,0,0,0) Enter Unaddressed Slave Mode, (STA,STO,SI,AA)=(1,0,0,1) Enter unad dressed slave mode, (STA,STO,SI,AA)=(0,0,0,1) Enter Unaddressed Slave Mode, responds to SLAs and Broadcasts (GC=1) (STA,STO,SI,AA)=(0,0,0,0) Enter unaddressed slave mode, does not respond to SLAs and does not respond to SLAs and broadcasts, and send START after can respond to SLA and broadcast (GC=1) and send START after the broadcasts the bus is idle bus is idle

Figure 20-12 Slave receive mode flow and register status



#### 20.4.8.4 Slave transmit mode

In slave transmit mode, data is transmitted from the slave to the master.

Before transmission, the slave needs to set the slave address: write the slave address to any one of the three slave address registers I2C\_ADDR0, I2C\_ADDR1, I2C\_ADDR2; set I2C\_CR.AA to 1 to respond to the master's addressing; I2C\_BRR The set value of the register is invalid, so it is not necessary to set it.

After completing the above initialization work, the slave machine enters the idle state (the slave receive mode is not addressed), waiting to be addressed by the read signal (SLA+R) transmitted by the master. After the slave receives SLA+R, if the address matches I2C\_ADDR0/1/2, the slave responds with ACK and enters the addressed slave transmit mode, the status code I2C\_STAT becomes 0xA8, and the interrupt flag bit I2C\_CR.SI Also set to 1. At this time, the data to be transmitted should be written into the I2C\_DR register in time, and the I2C\_CR.SI bit should be cleared, waiting for 1 byte of data to be transmitted, and ACK confirmation after each byte of data is transmitted until all data is transmitted.

If the slave receives a NACK response during transmission, the slave no longer transmits data and enters the unaddressed slave receive mode.

If the slave actively sets I2C\_CR.AA to 0 during the transmission process, the slave switches itself to the unaddressed slave receive mode after transmitting the last 1 byte of valid data, after which the master will get 0xFF when reading data from the bus.

When the master loses arbitration due to bus conflict in the SLA+ read and write stage, it will enter the unaddressed slave receive mode, and then if it receives SLA+R that matches the local address and responds with ACK (status code I2C\_STAT=0xB0), it will enter addressed slave transmit mode.

The state synchronization diagram in slave transmit mode is shown in the following figure:



Figure 20-13 The status synchronization diagram of slave transmit mode

The data transmission flow chart and status register value in slave transmit mode are shown in the following figure:



Rev 1.0



Figure 20-14 Slave transmit mode flow and register status



#### 20.4.8.5 Broadcast receive mode

The broadcast receive mode is a special slave receive mode. When the slave is in an idle state (the slave receive mode is not addressed), the broadcast receive mode is entered when the SLA+W transmitted by the master is received, and the SLA is broadcast address 0x00. In this mode, the data reception process is the same as the slave receive mode, but the I2C bus status code is different.

To receive the broadcast information transmitted by the master, the slave needs to set I2C\_CR.AA to 1 and I2C\_ADDR0.GC to 1 to respond to the master's broadcast addressing and broadcast data; the three slave address registers I2C\_ADDR0/1/2 do not need to be set; The value of I2C\_BRR is invalid and does not need to be set.

After completing the above initialization work, the slave machine enters the idle state (the slave receive mode is not addressed), waiting to be addressed by the write signal (SLA+W) transmitted by the master. When the slave receives SLA+W, if the address matches the broadcast address 0x00, the slave responds with an ACK response and enters the broadcast receive mode, the status code I2C\_STAT becomes 0x70, and the interrupt flag bit I2C\_CR.SI is set to 1 at the same time. At this time, the I2C\_CR.SI bit must be cleared in time to receive the data transmitted by the master from the bus.

Every time the slave receives 1 byte of data, it must respond with an ACK response. After the application reads the byte of data, it must clear the I2C\_CR.SI bit to prepare for receiving the next byte of data.

In the process of receiving data from the slave, if I2C\_CR.AA is cleared, the slave will return the NACK signal when it receives the next byte, and the state of the slave will also switch to the unaddressed slave receive mode, ending communication with the master, no more data is received, and the I2C\_DR register holds the previously received data. It can be seen from this feature that the slave application can actively switch from the addressed broadcast reception mode to the unaddressed slave receive mode by setting I2C\_CR.AA to 0.

When the master loses arbitration due to bus conflict in the SLA+ read and write stage, it will enter the unaddressed slave receive mode, and then if it receives SLA+W that conforms to the broadcast address and responds with ACK (status code I2C\_STAT=0x78), it will enter the addressed broadcast receive mode.

The data reception flow chart and status register value in broadcast receive mode are shown in the following figure:



(STA,STO,SI,AA)=(0,0,0,1) write GC=1, AA=1, enable broadcast and ACK response  $I2C_STAT = 0x70$ Broadcast address received, and ACK returned  $I2C_STAT = 0x78$ Master lost arbitration transfer in Broadcast address received, and ACK returned (STA,STO,SI,AA)=(X,0,0,X)(STA,STO,SI,AA)=(X,0,0,1)(STA,STO,SI,AA)=(X,0,0,0)write SI =0, write AA=1, write SI=0 write AA=0, write SI=0 waiting to receive repeated waiting to receive 1 byte of data waiting to receive 1 byte of data START or STOP signals  $I2C_STAT = 0x90$  $I2C_STAT = 0x98$  $I2C_STAT = 0xA0$ 1 byte of data has been received, 1 byte of data has been received, Received repeated START or and ACK has been returned STOP signals and NACK has been returned (STA,STO,SI,AA)=(1,0,0,0) Enter un addressed slave mode, (STA,STO,SI,AA)=(1,0,0,1) Enter unaddressed slave mode, (STA,STO,SI,AA)=(0,0,0,1) Enter unad dressed Slave Mode, Responds to SLAs and Broadcasts (STA,STO,SI,AA)=(0,0,0,0) Enter unaddressed slave mode, does not respond to SLAs and do not respond to SLA and broadcast, and send START after can respond to SLA and broadcast (GC=1) and send START after the broadcasts (GC=1) the bus is idle bus is idle

Figure 20-15 Broadcast receive mode flow and register status



#### 20.4.9 Multi-master communication

In some applications, there are two or more masters accessing the slave at the same time on one I2C bus, and it is possible to transmit data at the same time. At this time, there will be data conflicts on the SDA bus.

The I2C of the CW32W031 can perform data conflict detection and arbitration on the SDA bus to achieve multimaster applications. If two masters transmit data at the same time, the master that detects the conflict will lose arbitration and enter the unaddressed slave mode, and the master that has not detected the conflict will win the arbitration and continue to dominate the data communication flow.

#### 20.4.10 I2C status codes

The I2C bus status is identified by the I2C status register I2C\_STAT, with a total of 26 normal receiving or transmitting statuses, and 2 special statuses (0xF8: no information available on the I2C bus; 0x00: bus error).

Whether I2C is in master transmit, master receive, slave receive, slave transmit or broadcast receive mode, when the content of the status register I2C\_STAT changes, I2C\_CR.SI will be set and an I2C interrupt will be generated.

The I2C status codes are shown in the following table:

Table 20-3 I2C status codes

| Operating mode  | Status code | Meaning                                                                                   |
|-----------------|-------------|-------------------------------------------------------------------------------------------|
|                 | 08H         | Start signal has been transmitted                                                         |
|                 | 10H         | Repeated start signal has been transmitted                                                |
|                 | 18H         | SLA+W has been transmitted, ACK has been received                                         |
| Master transmit | 20H         | SLA+W has been transmitted, NACK has been received                                        |
| mode            | 28H         | Data in I2C_DR has been transmitted, ACK has been received                                |
|                 | 30H         | Data in I2C_DR has been transmitted, NACK has been received                               |
|                 | 38H         | The master loses arbitration during sending SLA+W phase or during transmitting data phase |
|                 | 08H         | Start signal has been transmitted                                                         |
|                 | 10H         | Repeated start signal has been transmitted                                                |
| Master receive  | 38H         | Host loses arbitration during transmitting SLA+R phase or responding to NACK phase        |
| mode            | 40H         | SLA+R has been transmitted, ACK has been received                                         |
|                 | 48H         | SLA+R has been transmitted, NACK has been received                                        |
|                 | 50H         | Data bytes have been received, ACK has been returned                                      |
|                 | 58H         | Data bytes have been received, NACK has been returned                                     |

| Operating mode         | Status code | Meaning                                                                                                                                 |  |
|------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|
|                        | 60H         | Its own SLA+W has been received, ACK has been returned                                                                                  |  |
|                        | 68H         | When the master loses arbitration in the SLA+read-write phase, its own SLA+W has been received, and ACK has been returned               |  |
| Slave receive<br>mode  | 80H         | The previous addressing used its own slave address, the data byte has been received, and ACK has been returned                          |  |
|                        | 88H         | The previous addressing used its own slave address, the data byte has been received, and NACK has been returned                         |  |
|                        | A0H         | STOP or Repeated START condition is received while the addressed slave is waiting to receive data                                       |  |
|                        | A8H         | Its own SLA+R has been received, ACK has been returned                                                                                  |  |
| Slave transmit         | ВОН         | When the master loses arbitration in the SLA+read-write phase, its own SLA+R has been received, and ACK has been returned               |  |
| mode                   | B8H         | Data bytes have been transmitted, ACK has been received                                                                                 |  |
|                        | СОН         | Data bytes have been transmitted, NACK has been received                                                                                |  |
|                        | C8H         | Slave last data byte has been transmitted and ACK has been received                                                                     |  |
|                        | 70H         | The broadcast address (0x00) has been received, ACK has been returned                                                                   |  |
|                        | 78H         | When the master loses arbitration in the SLA + read and write phase, the broadcast address has been received, and ACK has been returned |  |
| Broadcast receive mode | 90H         | The previous addressing used the broadcast address, the data byte has been received, and the ACK has been returned                      |  |
|                        | 98H         | The previous addressing used the broadcast address, the data byte has been received, and NACK has been returned                         |  |
|                        | A0H         | STOP or Repeated START condition is received while the addressed slave is waiting to receive data                                       |  |
|                        | F8H         | No relevant status information available, I2C_CR.SI=0                                                                                   |  |
| Others                 | 00H         | A bus error occurred during the transfer, or external interference caused the I2C to enter an undefined state                           |  |

The special status code F8H indicates that there is no useful information at the current moment, and the current bus status cannot be determined, because I2C\_CR.SI has not been set, and no interrupt is generated. This condition occurs before other states and the I2C module has started to perform a serial transfer.

The special status code 00H indicates that there is a bus error during the I2C serial transmission, such as the START or STOP signal appears in the wrong position of the data frame (including the address byte, data byte or response bit in the serial transmission process) or when external interference affects the internal I2C module signal, etc. When a bus error occurs, the I2C\_CR.SI flag is immediately set, and the device is immediately switched to unaddressed slave receive mode, releasing SDA and SCL, and clearing the I2C\_DR register.

When it is detected that the STAT of the I2C bus is a bus error (status code is 00H), since the I2C bus is continuously enabled, and the error has not been cleared for the I2C module, SI will continue to remain 1, that is, SI cannot be cleared.

Bus error clearing method:

- 1. Transmit a STOP signal to the bus: set the STO bit and clear the SI bit (due to the current bus error state, the controller does not actually transmit the STOP signal to the bus), the STO bit will be automatically cleared by hardware, releasing the bus to normal idle state.
- 2. If the SI bit cannot be cleared by setting the STO bit, it means that the timing has been disrupted. It is necessary to set I2C\_CR.EN to 0 and 1 in turn, that is, shut down and restart the I2C module, and then set SI to 0 to clear the SI bit.

In each operating mode, the I2C bus state transition diagram is shown in the following figure. Caution that when transitioning between the two normal states, when the action is not completed (such as in the process of transmitting SLA), that is, before entering a new state, the status code will appear a short-term transition state, 0xF8. The user does not care, and no interruption is generated.



Figure 20-16 The status transition diagram of master transmit/receive mode

Slave transmit/receive mode Status F8H Receive own address SLA+W, return ACK Receive own address SLA+R, return ACK Normal working condition Slave receive mode Slave transmit mode Send the last DATA, receive ACK Status A8H/B0H<sup>2</sup> Status 60H/68H<sup>1</sup> Send DATA, receive ACK Status C8H Receive DATA, return NACK Send the last DATA, receive ACK Receive DATA Return ACK Send DATA Status 80H Status B8H ,MG Receive STOP or receive REPEAT START Status 88H Status A0H Status C0H Unaddressed slave receive mode Unaddressed slave receive mode Caution 1: When the master loses arbitration in the SLA+ read and write stage and enters the unaddressed slave state (status code 0x38), it receives its own SLA+W and returns ACK;
Caution 2: When the master loses arbitration in the SLA+ read and write stage and enters the unaddressed slave state (status code 0x38), it receives its own SLA+R and returns ACK;

Figure 20-17 The status transition diagram of slave transmit/receive mode



Receive STOP or REPEATED START

Status AOH

Caution: When the master loses arbitration in the SIA+ read and write stage and enters the unaddressed slave state (status code 0x38), it receives the broadcast address SIA+W and returns ACK;

Figure 20-18 The status transition diagram of broadcast receive mode

### 20.5 Programming examples

### 20.5.1 Master transmits example

Step 1: According to the relevant description of the pin digital multiplexed function in the GPIO chapter, map SCL and SDA to the required pins, and configure the SCL and SDA pins as open-drain output mode;

- Step 2: Set SYSCTRL\_APBEN1.I2C to 1 to enable the I2C module clock;
- Step 3: Write 0 and 1 to SYSCTRL\_APBRST1.I2C in turn to reset the I2C module;
- Step 4: Configure I2C\_BRR to make the clock rate of SCL meet the application requirements;
- Step 5: Set I2C\_BRREN to 1 to enable the SCL clock generator;
- Step 6: Set I2C\_CR.EN to 1 to enable the I2C module;
- Step 7: Set I2C\_CR.STA to 1, the bus tries to transmit a START signal;
- Step 8: Wait for I2C\_CR.SI to become 1, START signal has been transmitted to the bus;
- Step 9: Query I2C\_STAT, if the register value is 0x08 or 0x10, continue to the next step, otherwise, perform error processing;
- Step 10: Write SLA+W to I2C\_DR, set I2C\_CR.STA to 0, set I2C\_CR.SI to 0, and transmit SLA+W;
- Step 11: Wait for I2C\_CR.SI to become 1, SLA+W has been transmitted to the bus;
- **Step 12:** Query I2C\_STAT, if the register value is 0x18, continue to the next step, otherwise, perform error processing;
- Step 13: Write the data to be transmitted to I2C\_DR, set I2C\_CR.SI to 0, and transmit the data;
- Step 14: Wait for I2C\_CR.SI to become 1, the data has been transmitted to the bus;
- Step 15: Query I2C\_STAT, if the register value is 0x28, continue to the next step, otherwise, perform error processing;
- Step 16: If the data to be transmitted is not completed, then jump to step 13 and continue to execute;
- Step 17: Set I2C\_CR.STO to 1, set I2C\_CR.SI to 0, transmit STOP signal, and end this data transfer.



450 / 572 Rev 1.0

### 20.5.2 Master receives example

Step 1: According to the relevant description of the pin digital multiplexed function in the GPIO chapter, map SCL and SDA to the required pins, and configure the SCL and SDA pins as open-drain output mode;

- Step 2: Set SYSCTRL\_APBEN1.I2C to 1 to enable the I2C module clock;
- Step 3: Write 0 and 1 to SYSCTRL\_APBRST1.I2C in turn to reset the I2C module;
- Step 4: Configure I2C\_BRR to make the clock rate of SCL meet the application requirements;
- Step 5: Set I2C\_BRREN to 1 to enable the SCL clock generator;
- Step 6: Set I2C\_CR.EN to 1 to enable the I2C module;
- Step 7: Set I2C\_CR.STA to 1, the bus tries to transmit a START signal;
- Step 8: Wait for I2C\_CR.SI to become 1, START signal has been transmitted to the bus;
- Step 9: Query I2C\_STAT, if the register value is 0x08 or 0x10, continue to the next step, otherwise, perform error processing;
- Step 10: Write SLA+W to I2C\_DR, set I2C\_CR.STA to 0, set I2C\_CR.SI to 0, and transmit SLA+R;
- Step 11: Wait for I2C\_CR.SI to become 1, SLA+R has been transmitted to the bus;
- Step 12: Query I2C\_STAT, if the register value is 0x40 (ACK has been received), continue to the next step, otherwise, perform error processing;
- Step 13: Set I2C\_CR.AA to 1, enable the response flag;
- Step 14: Set I2C\_CR.SI to 0, waiting to receive 1 byte of data (the master transmits the clock, and the slave transmits data under the action of the clock);
- Step 15: Wait for I2C\_CR.SI to become 1 (the host has completed the 1-byte data reception and has responded to the ACK signal), and read the received data from I2C\_DR;
- **Step 16:** Query I2C\_STAT, if the register value is 0x50 or 0x58, continue to the next step, otherwise, perform error processing;
- Step 17: If the data to be received is only missing the last byte, set I2C\_CR.AA to 0, and enable the non-response flag;
- Step 18: If the data to be received is not completed, then jump to step 14 and continue to execute;
- Step 19: Set I2C\_CR.STO to 1, set I2C\_CR.SI to 0, transmit STOP signal, and end this data transfer.



### 20.5.3 Slave receives example

Step 1: According to the relevant description of the pin digital multiplexed function in the GPIO chapter, map SCL and SDA to the required pins, and configure the SCL and SDA pins as open-drain output mode;

- Step 2: Set SYSCTRL\_APBEN1.I2C to 1 to enable the I2C module clock;
- Step 3: Write 0 and 1 to SYSCTRL\_APBRST1.I2C in turn to reset the I2C module;
- Step 4: Set I2C\_CR.EN to 1 to enable the I2C module;
- Step 5: Configure I2C\_ADDR0 as the slave address;
- Step 6: Set I2C\_CR.AA to 1, enable the response flag;
- Step 7: Wait for I2C\_CR.SI to become 1 and be addressed by SLA+W;
- Step 8: Query I2C\_STAT, if the register value is 0x60, continue to the next step, otherwise, perform error processing;
- Step 9: Set I2C\_CR.SI to 0, wait for the master to transmit data, and respond to the ACK signal;
- Step 10: Wait for I2C\_CR.SI to become 1, and read the received data from I2C\_DR;
- Step 11: Query I2C\_STAT, if the register value is 0x80, continue to the next step, otherwise, perform error processing;
- Step 12: If the data to be received is not completed, then jump to step 9 and continue to execute;
- **Step 13:** Set I2C\_CR.AA to 0, set I2C\_CR.SI to 0, the slave switches to the unaddressed slave receive mode, and does not respond to master addressing.

### 20.5.4 Slave transmits example

- Step 1: According to the relevant description of the pin digital multiplexed function in the GPIO chapter, map SCL and SDA to the required pins, and configure the SCL and SDA pins as open-drain output mode;
- Step 2: Set SYSCTRL\_APBEN1.12C to 1 to enable the I2C module clock;
- Step 3: Write 0 and 1 to SYSCTRL\_APBRST1.I2C in turn to reset the I2C module;
- Step 4: Set I2C\_CR.EN to 1 to enable the I2C module;
- Step 5: Configure I2C\_ADDR0 as the slave address;
- Step 6: Set I2C\_CR.AA to 1, enable the response flag;
- Step 7: Wait for I2C\_CR.SI to become 1 and be addressed by SLA+R;
- **Step 8:** Query I2C\_STAT, if the value of this register is 0xA8, continue to the next step, otherwise, perform error processing;
- Step 9: Write the data to be transmitted to I2C\_DR, set I2C\_CR.SI to 0, and prepare to transmit data;
- Step 10: Wait for I2C\_CR.SI to become 1, indicating that the data has been transmitted to the bus and received an ACK or NACK response;
- **Step 11:** Query I2C\_STAT, if the value of this register is 0xB8, continue to the next step, otherwise, perform error processing;
- Step 12: If the data to be transmitted is not completed, then jump to step 9 to continue execution;
- Step 13: Set I2C\_CR.AA to 0, set I2C\_CR.SI to 0, the slave switches to the unaddressed slave receive mode, and does not respond to master addressing.



452 / 572 Rev 1.0

# 20.6 List of registers

I2C base address: I2C\_BASE = 0x4000 5400

Table 20-4 List of I2C registers

| Register name | Register address | Register description                     |
|---------------|------------------|------------------------------------------|
| I2C_BRREN     | I2C_BASE + 0x00  | Baud rate counter enable register        |
| I2C_BRR       | I2C_BASE + 0x04  | Baud rate counter configuration register |
| I2C_CR        | I2C_BASE + 0x08  | Control register                         |
| I2C_DR        | I2C_BASE + 0x0C  | Data register                            |
| I2C_ADDR0     | I2C_BASE + 0x10  | Slave address 0 register                 |
| I2C_STAT      | I2C_BASE + 0x14  | Status register                          |
| I2C_ADDR1     | I2C_BASE + 0x20  | Slave address 1 register                 |
| I2C_ADDR2     | I2C_BASE + 0x24  | Slave address 2 register                 |
| I2C_MATCH     | I2C_BASE + 0x28  | Slave address match flag register        |

# 20.7 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

# 20.7.1 I2C\_BRREN baud rate counter enable register

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                  |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1      | RFU  | -          | Reserved bits, please keep the default value                                                                                                          |
| 0         | EN   | RW         | I2C bus SCL baud rate counter enable control 0: Disabled 1: Enabled Caution: EN should be enabled when the master, this bit does not affect the slave |

# 20.7.2 I2C\_BRR baud rate counter configuration register

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                   |
|-----------|------|------------|----------------------------------------------------------------------------------------|
| 31:8      | RFU  | -          | Reserved bits, please keep the default value                                           |
| 7:0       | BRR  | RW         | I2C bus SCL baud rate configuration $f_{SCL} = f_{PCLK} / 8 / (BRR+1)$ , where BRR > 0 |

# 20.7.3 I2C\_CR control register

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6         | EN   | RW         | Module enable control 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5         | STA  | RW         | Bus Status Control W0: Clear STA W1: Send START signal to the bus Caution 1: After setting STA to 1, if the bus is idle, send the START signal, if the bus is busy, wait for the I2C to stop, and then send the START signal. Caution 2: If the device is already in master mode and has sent one or more bytes, and then set STA at this time, the I2C bus will generate a Repeated START signal. Caution 3: STA can be set at any time, including slave mode. However, the hardware will not automatically clear 0 after the completion of the START or repeat START signal transmission, and the user needs to manually clear STA. |
| 4         | STO  | RW         | Bus Status Control W0: No function W1: Send STOP signal to bus Caution 1: The hardware will automatically clear STO to 0 after the completion of the STOP signal transmission. Caution 2: If STA and STO are set at the same time in master mode, the I2C bus sends START immediately after sending STOP. In slave mode, it is forbidden to set STA and STO at the same time to avoid sending illegal I2C frames. Caution 3: STO is also set to 1 when an error state occurs on the bus (STAT status word is 00H), but the I2C bus will not send a STOP signal in this case.                                                          |

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3         | SI   | RW         | I2C interrupt flags R0: No I2C interrupt occurred R1: I2C interrupt has occurred W0: Clear the I2C interrupt flag and cause the status machine to execute the next action W1: No function Caution 1: If one of the 26 states of I2C occurs, the hardware will set this bit (except F8H) to 1. At this time, the software confirms the current status of the bus through the I2C_STAT register value. Caution 2: SI needs to be cleared by software. Caution 3: Before SI is cleared to 0, the SCL low level period is extended and the transmission is suspended. This status is very useful for the slave to process the received data, which can ensure that the previous data is accurately processed before the next data is received. Caution 4: Before software clears SI, software should prepare appropriate register settings. After SI is cleared, the I2C bus will perform the corresponding operation according to the register settings. |
| 2         | AA   | RW         | Response control 0: Transmit NACK in response phase 1: Transmit ACK in response phase Caution 1: For the addressed slave, if no ACK response bit is returned in slave receive mode or no ACK response bit is received in slave transmit mode, the slave will switch to unaddressed slave receive mode, cannot receive data until its AA is set and re-addressed by the master. Caution 2: Special case: in slave transmit mode, before the slave transmits the last byte to the master, clear AA. After transmitting the last byte, the slave will switch to the unaddressed slave mode and be disconnected from the master, the status register I2C_STAT is C8H. If the master reads data from the bus again, it will get 0xFF.                                                                                                                                                                                                                      |
| 1         | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0         | FLT  | RW         | I2C filter parameter configuration 0: Advanced filtering, higher anti-interference performance 1: Simple filtering, faster communication rate Caution: See section 20.4.3 Input filter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# 20.7.4 I2C\_DR data register

Address offset: 0x0C Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                               |
|-----------|------|------------|----------------------------------------------------------------------------------------------------|
| 31:8      | RFU  | -          | Reserved bits, please keep the default value                                                       |
| 7:0       | DR   | RW         | Data register In transmit mode, write the transmitted data In receive mode, read the received data |

# 20.7.5 I2C\_STAT status register

Address offset: 0x14 Reset value: 0x0000 00F8

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                       |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                               |
| 7:0       | STAT | RO         | I2C status register, see section 20.4.10 I2C status codes for the specific definition of status value; when STAT = F8H, it means that there is no relevant status information available, and SI will remain at 0. For the other 26 states, SI will be set to 1 and an interrupt request will be generated. |

# 20.7.6 I2C\_ADDR0 slave address 0 register

Address offset: 0x10 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8      | RFU   | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7:1       | ADDR0 | RW         | Slave mode address 0 Caution 1: The master mode is invalid. Caution 2: The master needs to address the slave, and the address information must be the same as this address through the first byte value address information after START or Repeated START. If AA is 1, the slave responds to the master and becomes the addressed slave, otherwise the master broadcast addressing information will be ignored. Caution 3: I2C_ADDR0[7:1] cannot be written as all 0, because 0x00 is reserved for broadcast addressing. |
| 0         | GC    | RW         | Broadcast address response enabled 0: Disabled 1: Enabled Caution 1: The master mode is invalid. Caution 2: After enabling GC, if AA is set to 1, the broadcast receive mode is enabled, and if AA is cleared to 0, the broadcast addressing information on the bus is ignored.                                                                                                                                                                                                                                          |

# 20.7.7 I2C\_ADDR1 slave address 1 register

Address offset: 0x20 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                         |
|-----------|-------|------------|--------------------------------------------------------------|
| 31:8      | RFU   | -          | Reserved bits, please keep the default value                 |
| 7:1       | ADDR1 | RW         | Slave mode address 1<br>Caution: The master mode is invalid. |
| 0         | RFU   | -          | Reserved bits, please keep the default value                 |

# 20.7.8 I2C\_ADDR2 slave address 2 register

Address offset: 0x24 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                         |
|-----------|-------|------------|--------------------------------------------------------------|
| 31:8      | RFU   | -          | Reserved bits, please keep the default value                 |
| 7:1       | ADDR2 | RW         | Slave mode address 2<br>Caution: The master mode is invalid. |
| 0         | RFU   | -          | Reserved bits, please keep the default value                 |

# 20.7.9 I2C\_MATCH slave address match register

Address offset: 0x28 Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                                                                                                                          |
|-----------|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3      | RFU   | -          | Reserved bits, please keep the default value                                                                                                                                  |
| 2         | ADDR2 | RO         | I2C slave mode address 2 match flag bit 0: The device address received from the bus is not the same as ADDR2 1: The device address received from the bus is the same as ADDR2 |
| 1         | ADDR1 | RO         | I2C slave mode address 1 match flag bit 0: The device address received from the bus is not the same as ADDR1 1: The device address received from the bus is the same as ADDR1 |
| 0         | ADDR0 | RO         | I2C slave mode address 0 match flag bit 0: The device address received from the bus is not the same as ADDR0 1: The device address received from the bus is the same as ADDR0 |

### Caution:

The address match flag bit will be cleared in the following three cases:

- When the module is reset;
- When START/STOP is transmitted.



# 21 Infrared modulation transmitter (IR)

### 21.1 Overview

The CW32W031 integrates an infrared modulation transmitter (IR), which can be used in conjunction with UART through two general-purpose timers or one general-purpose timer, which can easily implement various standard PWM or PPM encoding methods, and can and also realize infrared modulation transmission of UART data.

### 21.2 Main features

- Supports SIR of IrDA standard 1.0
- Maximum data rate 115.2kbps
- Can adapt to high and low level infrared emission tube

### 21.3 Functional description

When the infrared modulation transmitter is implemented, a general timer channel is used to generate a square wave signal with a fixed frequency, and another general timer or UART is used to generate modulation data. After 'AND' or 'OR' operation of the two, it is converted from IR\_OUT pin output, for specific IR\_OUT pins, please refer to the pin definitions in the data sheet. The schematic diagram of internal connection of IR is shown in the following figure:

Data signal

UART1\_TXD

UART2\_TXD

GTIM1\_CH1

GTIM1\_CH2

GTIM1\_CH2

GTIM2\_CH1

GTIM2\_CH2

Figure 21-1 Schematic diagram of internal connection of IR

The IR infrared modulation control register SYSCTRL\_IRMOD is used to select the source of the carrier signal and the data signal, as well as the 'AND' or 'OR' operation of the two. The choice of 'AND' and 'OR' is determined by the drive level of the user's hardware infrared emitter.

The carrier signal frequency can be set by the user, the most common carrier frequency is 38KHz.

In order to reduce the transmission power consumption, the duty cycle of the carrier is generally set to about 20%, and the timer that generates the carrier can use the PWM mode, please refer to chapter *14 General-purpose timer (GTIM)*. In order to increase the transmission distance, the duty cycle can be appropriately increased. In the IrDA standard 1.0, in order to achieve a fast IR communication rate, the width of the pulse is specified as 3/16 of a bit period or a fixed  $1.63 \, \mu s$ , and the minimum cannot be lower than  $1.41 \mu s$ .

#### 21.3.1 Infrared modulation mode

There are two common IR infrared encoding methods, pulse width modulation PWM and pulse position modulation PPM.

PWM pulse width modulation to represent '0' and '1' with the duty cycle of the transmitted infrared carrier. For example, UPD6121, the carrier transmits 0.56ms, and does not transmit 0.56ms, which means '0'; the carrier transmits 0.56ms, and does not transmit 1.68ms, which means '1'. The reference diagram is shown in the following figure:



Figure 21-2 PWM modulation mode

PPM pulse position modulation to represent '0' and '1' with the position of the transmitted carrier. It is '0' from transmitting carrier to not transmitting carrier, and '1' from never transmitting carrier to transmitting carrier. For example, SAA3010, the carrier transmits 0.84ms, and does not transmit 0.84ms, which means '0'; does not transmit 0.84ms, and the carrier transmits 0.84ms, means '1'. The reference diagram is shown in the following figure:



Figure 21-3 PPM modulation mode

UART modulation is a relatively simple infrared modulation method, which directly performs 'AND' or 'OR' operation on serial data and carrier signal. When the UART serial baud rate is lower than the carrier frequency, the reference schematic diagram is shown in the following figure:

Figure 21-4 UART modulation mode



When the UART serial baud rate is higher than the carrier frequency, the carrier pulse width should be set to 3/16 of the bit width, and the carrier frequency should be kept consistent with the serial frequency. For example, when the UART baud rate is set to 115.2Kbps, the carrier frequency is also set to 115.2KHz, and the width of the carrier pulse is  $1.63\mu s$  (3/16×1/115200Hz =  $1.63\mu s$ ). The reference schematic diagram is shown in the following figure:

Figure 21-5 High-speed UART modulation mode



For the convenience of debugging, usually a standard data frame also includes boot code, end bit, retransmission code, etc. Please refer to the relevant data manual by yourself.

### 21.3.2 Infrared modulation initialization configuration

The initialization process of a complete IR infrared modulation transmitter should include the configuration of timer, UART, and GPIO. The reference steps are as follows:

- Step 1: Set the SYSCTRL\_APBEN1 and SYSCTRL\_APBEN2 registers to enable the timer and UART peripheral clock to be selected;
- Step 2: Set the allowed bits of the GPIO clock corresponding to the IR\_OUT pin in the SYSCTRL\_AHBEN register.
- Step 3: Configure the timer selected as the carrier, set the carrier frequency, duty cycle (common frequency 38KHz, 1/3 duty cycle), and set the timer working mode (PWM output is recommended);
- Step 4: Configure the timer or UART selected as data, set the bit width, and UART working mode (no need to define output pins);
- Step 5: Set GPIOx\_ANALOG as IR\_OUT output port as digital mode, set GPIOx\_DIR as output, and set appropriate GPIOx\_OPENDRAIN, GPIOx\_PUR and GPIOx\_PDR;
- Step 6: Start the timer and UART as carrier and data;
- Step 7: Set the MOD bit field of the IR infrared modulation control register SYSCTRL\_IRMOD, and set the infrared modulation mode configuration;
- Step 8: Set the GPIOx\_AFRH of the IR\_OUT output port to IR\_OUT, and enable the IR multiplexing function.

### 21.3.3 Infrared reception

CW32W031 does not have an IR receiving demodulation module inside. In IR receiving applications, it is necessary to use an integrated infrared receiving head with demodulation function. With the capture function of GTIM (UART mode can directly use the RXD pin input), it can be easily realized IR receiving function.



# 21.4 SYSCTRL\_IRMOD infrared modulation control register

Address: 0x4001 0000 + 0x74 Reset value: 0x0000 0000

| Bit field | Name | Permission | Functional description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4      | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:0       | MOD  | RW         | Infrared modulation mode configuration 0000: GTIM1_CH1 & GTIM2_CH1 0001: GTIM1_CH1 & GTIM2_CH2 0010: GTIM1_CH2 & GTIM2_CH1 0011: GTIM1_CH2 & GTIM2_CH2 0100: GTIM1_CH2   GTIM2_CH2 0100: GTIM1_CH1   GTIM2_CH2 0110: GTIM1_CH2   GTIM2_CH2 0110: GTIM1_CH2   GTIM2_CH1 0111: GTIM1_CH2   GTIM2_CH2 1000: UART1_TXD & GTIM1_CH1 1001: UART1_TXD   GTIM1_CH1 1010: UART1_TXD   GTIM1_CH2 1101: UART1_TXD & GTIM1_CH2 1110: UART2_TXD & GTIM2_CH1 1110: UART2_TXD & GTIM2_CH1 1111: UART2_TXD & GTIM2_CH2 1111: UART2_TXD   GTIM2_CH2 |

# 22 Analog-to-digital converter (ADC)

#### 22.1 Overview

CW32W031 integrates a successive approximation analog-to-digital converter (SAR ADC) with a 12-bit precision and a maximum conversion speed of 1M SPS, which can convert up to 16 analog signals into digital signals. The vast majority of signals in the real world are analog, such as light, electricity, sound, image signals, etc., which must be converted into digital signals by ADC before they can be digitally processed by MCU.

#### 22.2 Main features

- 12-bit precision
- Programmable conversion speed, up to 1M SPS
- 16 channels of input conversion
  - 13 external pin inputs
  - Built-in temperature sensor
  - Built-in BGR 1.2V reference
  - 1/3 VDDA supply voltage
- 4-channel reference voltage source (Vref)
  - VDDA supply voltage
  - ExRef (PB00) pin voltage
  - Built-in 1.5V reference voltage
  - Built-in 2.5V reference voltage
- Sampling voltage input range: 0 ~ V<sub>ref</sub>
- Multiple conversion modes, all support conversion accumulation function
  - Single conversion
  - Multiple conversions
  - Continuous conversion
  - Sequence scan conversion
  - Sequence discontinuous conversion
- Supports single channel and sequence channel selection, and supports up to 8 sequences at the same time
- Supports input channel voltage threshold monitoring
- Built-in signal follower to convert high impedance input signals
- Supports on-chip peripherals to automatically trigger ADC conversion
- Support ADC conversion to complete triggering DMA

# 22.3 Functional block diagram

The ADC functional block diagram is shown in the following figure:

Figure 22-1 ADC functional block diagram



## 22.4 Conversion timing, conversion speed, conversion accuracy, and conversion results

## 22.4.1 Conversion timing

The conversion timing of the ADC is shown in the following figure:

Figure 22-2 ADC conversion timing diagram



Write 1 to the EN bit field of the ADC control register ADC\_CR0 to enable the ADC module.

About  $40\mu s$  after ADC\_CR0.EN changes from 0 to 1, the ADC\_ISR.READY flag is set to 1, indicating that the initialization of the analog circuit is completed, and the ADC conversion can be started.

Write 1 to the START bit field of the ADC start register ADC\_START to start the ADC conversion, and the hardware will automatically clear it after the conversion is completed.

The ADC working clock ADCCLK is obtained by dividing the system clock PCLK by the prescaler. The CLK bit field of the control register ADC\_CR0 can be selected to divide the frequency from 1 to 128, as shown in the following table:

Table 22-1 ADC clock configuration table

| ADC_CR0.CLK | ADCCLK   |
|-------------|----------|
| 000         | PCLK     |
| 001         | PCLK/2   |
| 010         | PCLK/4   |
| 011         | PCLK/8   |
| 100         | PCLK/16  |
| 101         | PCLK/32  |
| 110         | PCLK/64  |
| 111         | PCLK/128 |

A complete ADC conversion requires 24~29 ADCCLK clock cycles, including sampling phase and successive comparison phase:

1. Sampling phase: 5~10 ADCCLK clock cycles are required. The sampling period is configured by the SAM bit field of the control register ADC\_CRO, as shown in the following table:

Table 22-2 ADC sampling period selection table

| ADC_CR0.SAM | ADC sampling period (ADCCLK number) |
|-------------|-------------------------------------|
| 00          | 5                                   |
| 01          | 6                                   |
| 10          | 8                                   |
| 11          | 10                                  |

The length of the ADC sampling period is determined by the user's sampling speed requirements and the electrical characteristics of the sampling signal. The user should select an appropriate sampling period to achieve the best conversion effect.

2. Successive comparison phase: 19 ADCCLK clock cycles are required.

After the ADC conversion is completed, the conversion completion flag ADC\_ISR.EOC will be set to 1 by hardware, and the ADC conversion result is stored in the corresponding ADC conversion result register ADC\_RESULTy (y=0,1,2,3,4,5,6,7), the user can set ADC\_ICR.EOC to 0 to clear this flag.

### 22.4.2 Conversion speed

The ADC conversion speed is closely related to the ADC reference voltage and VDDA supply voltage, and the maximum conversion speed under various conditions is shown in the following table:

Table 22-3 ADC conversion speed and voltage comparison table

| ADC reference voltage | VDDA voltage | Maximum conversion speed | Maximum ADCCLK<br>frequency |
|-----------------------|--------------|--------------------------|-----------------------------|
| Internal 1.5V         | 1.8V ~ 2V    | 100K SPS                 | 2MHz                        |
| Internal 1.5V         | 2V ~ 3.6V    | 200K SPS                 | 4MHz                        |
| Internal 2.5V         | 2.8V ~ 3.6V  | 200K SPS                 | 4MHz                        |
| VDDA/ExRef            | 1.8V ~ 2V    | 100K SPS                 | 2MHz                        |
| VDDA/ExRef            | 2V ~ 2.4V    | 200K SPS                 | 4MHz                        |
| VDDA/ExRef            | 2.4V ~ 2.7V  | 500K SPS                 | 12MHz                       |
| VDDA/ExRef            | 2.7V ~ 3.6V  | 1M SPS                   | 24MHz                       |

The corresponding relationship between the conversion speed of the ADC and the working clock ADCCLK is as follows:

ADC conversion speed =  $f_{ADCCLK} / N_T$ 

Where, f<sub>ADCCLK</sub> is the clock frequency of ADCCLK, and N<sub>T</sub> is ADCCLK number required for one ADC conversion.



### 22.4.3 Conversion accuracy

When the ADC external input signal driving capability is insufficient, or the ADC input comes from the chip (built-in temperature sensor voltage, built-in 1.2V reference voltage or 1/3 VDDA voltage), the built-in signal follower of the ADC module must be enabled, and a single channel must be used. Single conversion mode. The built-in signal follower is controlled by the BUF bit field of the control register ADC\_CR0. Set BUF to 1 to enable the follower; set BUF to 0 to disable the follower.

When multi-channel ADC conversion is selected, and the signal driving capability of some of the channels is weak, in order to avoid the interference of the input channel with weak ADC driving capability, the signal follower must be enabled, and the ADC conversion speed must be no higher than 200K SPS.

To further improve the ADC conversion accuracy, the user can use the ADC conversion accumulation function to sample the same channel multiple times, and use the arithmetic mean of the accumulated results as the final measurement value. For details, please refer to section *22.6 Accumulation conversion function*.

#### 22.4.4 Conversion results

After the ADC conversion is completed, the 12-bit ADC conversion result is stored in the corresponding conversion result register ADC\_RESULTy.

When the ADC works in single-channel conversion mode, the conversion result is stored in the ADC\_RESULT0 register.

When the ADC works in the sequence conversion mode, the conversion result of the conversion sequence SQRy (y=0,1,2,3,4,5,6,7) is stored in the corresponding ADC\_RESULTy (y=0,1,2,3,4,5,6,7) register.

The conversion result register ADC\_RESULTy is 16 bits wide, and the user can choose left-aligned or right-aligned, which is determined by the ALIGN bit field of the control register ADC\_CR1:

- The ALIGN bit is 0, select right alignment, the effective value is stored in the lower 12 bits (bit 11:0) of the ADC\_RESULTy register, and the higher bits (bit 15:12) are automatically filled with 0;
- When the ALIGN bit is 1, the left alignment is selected, and the effective value is stored in the higher 12 bits (bit 15:4) of the ADC\_RESULTy register, and the lower bits (bit 3:0) are automatically filled with 0.

## 22.5 Operating modes

The MODE bit field of the ADC control register ADC\_CR0 configures the ADC operating mode, as shown in the following table:

Table 22-4 ADC operating mode configuration

| ADC_CR0.MODE | ADC operating mode                                                        |  |
|--------------|---------------------------------------------------------------------------|--|
| 000          | Single channel single conversion mode                                     |  |
| 001          | Single channel multiple conversion mode, see CR2.CNT for conversion times |  |
| 010          | Single channel continuous conversion mode                                 |  |
| 011          | Sequence continuous conversion mode                                       |  |
| 100          | Sequence scan conversion mode                                             |  |
| 101          | Sequence multiple conversion mode, see CR2.CNT for conversion times.      |  |
| 110          | Sequence intermittent conversion mode                                     |  |

The ADC conversion can be started by writing 1 to the START bit field of the ADC start register ADC\_START; it can also be triggered by other peripherals, see section 22.8 External trigger source.

## 22.5.1 Single channel single conversion mode (MODE=0)

After the ADC is started, a conversion is performed on a specified channel.

The ADC has 16 channels that can be selected, which is determined by the CHMUX bit field of the control register ADC\_CR1, as shown in the following table. Among them, AINO~AIN12 are external pin inputs, and the analog function of the corresponding GPIO must be enabled before use (GPIOx\_ANALOG.PINy = 1).

Table 22-5 Single channel configuration

| ADC_CR1.CHMUX | Channel selection                  | GPIO |
|---------------|------------------------------------|------|
| 0000          | AIN0                               | PA00 |
| 0001          | AIN1                               | PA01 |
| 0010          | AIN2                               | PA02 |
| 0011          | AIN3                               | PA03 |
| 0100          | AIN4                               | PA04 |
| 0101          | AIN5                               | PA05 |
| 0110          | AIN6                               | PA06 |
| 0111          | AIN7                               | PA07 |
| 1000          | AIN8                               | PB00 |
| 1001          | AIN9                               | PB01 |
| 1010          | AIN10                              | PB02 |
| 1011          | AIN11                              | PB10 |
| 1100          | AIN12                              | PB11 |
| 1101          | VDDA/3                             | -    |
| 1110          | TS built-in temperature sensor     | -    |
| 1111          | 1.2V core voltage reference source | -    |

In the single channel single conversion mode, after the ADC conversion is completed, the conversion completion flag ADC\_ISR.EOC will be automatically set to 1 by the hardware, the conversion result is stored in the ADC\_RESULTO register, and the START bit of the ADC start register ADC\_START is automatically cleared to 0, and the ADC conversion stop.

The timing of single channel single conversion mode is shown in the following figure:

Figure 22-3 Single channel single conversion timing diagram

The single conversion of the ADC single channel to the external analog input signal is started through the START bit. The reference operation flow is as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1 and SYSCTRL\_APBEN2.ADC to 1 to enable the GPIO clock and ADC working clock corresponding to the ADC channel;
- Step 2: Set the GPIO pin corresponding to the ADC channel to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set ADC\_CR0.EN to 1 to enable the ADC module;
- Step 4: Query and wait for the ADC\_ISR.READY bit to become 1, and wait for the ADC module to start up;
- Step 5: Set ADC\_CR0.MODE to 0, select single channel single conversion mode;
- Step 6: Configure ADC\_CRO.REF and select the reference voltage source of ADC;

### Caution:

If an external reference voltage pin is selected, this pin must be configured as an analog function first.

- Step 7: Configure ADC CR0.SAM and ADC CR0.CLK, set ADC sampling speed and clock selection;
- Step 8: Configure ADC\_CR1.CHMUX and select the channel to be converted;
- Step 9: Set ADC\_START.START to 1 to start ADC conversion;
- Step 10: Wait for ADC\_ISR.EOC to become 1, and read the ADC conversion result in the ADC\_RESULT0 register;
- Step 11: If it is necessary to convert other channels, repeat steps 8 to 10;
- Step 12: Set ADC\_CR0.EN to 0 to turn off the ADC module.



Start a single conversion of the ADC single channel to the external analog input signal through an external trigger, and use the ADC conversion completion interrupt to read the conversion result. The reference operation flow is as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1 and SYSCTRL\_APBEN2.ADC to 1 to enable the GPIO clock and ADC working clock corresponding to the ADC channel;
- Step 2: Set the GPIO pin corresponding to the ADC channel to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set ADC\_CR0.EN to 1 to enable the ADC module;
- Step 4: Query and wait for the ADC\_ISR.READY bit to become 1, and wait for the ADC module to start up;
- Step 5: Set ADC\_CR0.MODE to 0, select single channel single conversion mode;
- Step 6: Configure ADC\_CRO.REF and select the reference voltage of ADC;

#### Caution:

If an external reference voltage pin is selected, this pin must be configured as an analog function first.

- Step 7: Configure ADC\_CR0.SAM and ADC\_CR0.CLK, set ADC sampling speed and clock selection;
- Step 8: Set ADC\_IER.EOC to 1 to enable ADC conversion complete interrupt;
- Step 9: Enable ADC interrupt in NVIC interrupt vector table;
- Step 10: Set ADC\_ICR to 0x00, clear ADC interrupt flag;
- Step 11: Configure the external trigger register ADC\_TRIGGER and select the external trigger source;
- Step 12: Configure ADC\_CR1.CHMUX and select the channel to be converted;
- Step 13: Wait for the ADC to be triggered to start. When the ADC conversion is completed, the ADC\_ISR.EOC flag is set to 1 by hardware, and the MCU responds to the ADC interrupt and enters the ADC interrupt service routine. The user reads the ADC conversion result in the ADC\_RESULTO register; when exiting the service routine, the ADC\_ISR.EOC flag should be cleared first.;
- Step 14: If it is necessary to convert other channels, repeat steps 11 to 13;
- Step 15: Set ADC\_CR0.EN to 0 to turn off the ADC module.

### 22.5.2 Single channel multiple conversion mode (MODE=1)

After the ADC is started, it performs multiple conversions for a specified channel. The number of conversions is determined by the ADC\_CR2.CNT bit field value. The default number of conversion is 1.

In multiple conversion mode, the accumulation conversions function must be enabled, that is, setting ADC\_CR2.ACCRST to 1 clears the ADC\_RESULTACC register, while setting ADC\_CR2.ACCEN to 1 enables the automatic accumulation function of ADC conversion results.

After each ADC conversion is completed, the ADC\_ISR.EOC flag is automatically set to 1, the conversion result is stored in the ADC\_RESULT0 register, and the conversion result is automatically accumulated, and the accumulated value is stored in the ADC\_RESULTACC register. If the set ADC conversion times are not reached, the ADC will continue to convert; when the set ADC conversion times are reached, the multiple conversion completion flag ADC\_ISR.EOA is automatically set to 1, and the ADC\_START.START bit is automatically cleared to 0, the ADC conversion stops.

The timing of single channel multiple conversion mode is shown in the following figure:



Figure 22-4 Single channel multiple conversion timing diagram

The ADC single channel multiple conversion are started through the START bit. The reference operation flow is as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.ADC to 1, enable the GPIO clock corresponding to the ADC channel, the GPIO clock corresponding to the external reference voltage pin, and the ADC working clock;
- Step 2: Set the GPIO pin corresponding to the ADC channel to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set the GPIO pin corresponding to the external reference voltage to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;

#### Caution:

If the ADC reference voltage does not select the external reference voltage pin, skip this step.

- Step 4: Set ADC\_CR0.EN to 1 to enable the ADC module;
- Step 5: Query and wait for the ADC\_ISR.READY bit to become 1, and wait for the ADC module to start up;
- Step 6: Set ADC\_CR0.MODE to 1 and select single channel multiple conversions mode;
- Step 7: Configure ADC\_CRO.REF and select the reference voltage of ADC;
- Step 8: Configure ADC\_CR0.SAM and ADC\_CR0.CLK, set ADC sampling speed and clock selection;
- Step 9: Configure ADC\_CR1.CHMUX and select the channel to be converted;
- Step 10: Configure ADC\_CR2.CNT and set the conversion times;
- **Step 11:** Set ADC\_CR2.ACCRST and ADC\_CR2.ACCEN to 1 to enable the conversion result accumulation function;
- Step 12: Set ADC\_IER.EOA to 1 to enable multiple conversion completion interrupts;
- Step 13: Enable ADC interrupt in NVIC interrupt vector table;
- Step 14: Set ADC\_ICR.EOA to 0, clear the EOA interrupt flag;
- Step 15: Set ADC\_START.START to 1 to start ADC conversion;
- Step 16: Query and wait for ADC\_ISR.EOA to become 1, indicating that multiple conversions are completed, ADC\_START.START bit is automatically cleared to 0, and ADC conversion stops. At this time, the user can read the ADC\_RESULTACC register to obtain the accumulated value of the ADC conversion result, and divide it by the conversion times to obtain the ADC conversion result;
- Step 17: If you need to convert other channels, repeat steps 9 to 16;
- Step 18: Set ADC\_CR0.EN to 0 to turn off the ADC module.

### 22.5.3 Single channel continuous conversion mode (MODE=2)

In this mode, whether the ADC is started by the software START bit or the external trigger, once the ADC is started, it will continue to convert a specified channel until the ADC\_START.START bit is cleared to 0, and the conversion will not be stopped.

After each ADC conversion is completed, the ADC\_ISR.EOC flag is automatically set to 1, and the conversion result is stored in the ADC\_RESULT0 register. The user should read the conversion result in ADC\_RESULT0 in time to avoid conversion result overflow. User writes 0 to ADC\_START.START bit to stop conversion.

The timing of single channel continuous conversion mode is shown in the following figure:

Figure 22-5 Single channel continuous conversion timing diagram

The ADC single channel continuous conversion is started through the START bit, and the reference operation flow is as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.ADC to 1, enable the GPIO clock corresponding to the ADC channel, the GPIO clock corresponding to the external reference voltage pin, and the ADC working clock;
- Step 2: Set the GPIO pin corresponding to the ADC channel to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set the GPIO pin corresponding to the external reference voltage to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;

#### Caution:

If the ADC reference voltage does not select the external reference voltage pin, skip this step.

- Step 4: Set ADC\_CR0.EN to 1 to enable ADC module;
- Step 5: Query and wait for the ADC\_ISR.READY bit to become 1, and wait for the ADC module to start up;
- Step 6: Set ADC\_CR0.MODE to 2, select single channel continuous conversion mode;
- Step 7: Configure ADC\_CRO.REF and select the reference voltage of ADC;
- Step 8: Configure ADC\_CR0. SAM and ADC\_CR0. CLK, set ADC sampling speed and clock selection;
- Step 9: Configure ADC\_CR1.CHMUX and select the channel to be converted;
- Step 10: Set ADC\_START.START to 1 to start ADC conversion;
- Step 11: Query and wait for ADC\_ISR.EOC to become 1, and continuously read the ADC\_RESULT0 register to obtain the ADC conversion result;
- Step 12: Set ADC\_START.START to 0 to stop ADC conversion;
- Step 13: If you need to convert other channels, repeat steps 9 to 13;
- Step 14: Set ADC CR0.EN to 0 to turn off the ADC module.



477 / 572 Rev 1.0

### 22.5.4 Sequence continuous conversion mode (MODE=3)

Sequence continuous conversion mode is similar to single channel continuous conversion mode, except that the sequence continuous conversion mode can alternately convert up to 8 sequence channels instead of a single channel, and each sequence SQRy can select one of 16 conversion channels, which is configured by the SQRy bit field of the sequence configuration register ADC\_SQR0 and ADC\_SQR1. The sequence configuration to be converted is determined by the ENS bit field of the ADC sequence configuration register ADC\_SQR0, as shown in the following table:

ADC\_SQR.ENS The sequence configuration to be converted 000 Only SQR0 is converted 001 Convert SQR0, SQR1 010 Convert SQR0, SQR1, SQR2 011 Convert SQR0, SQR1, SQR2, SQR3 100 Convert SQR0, SQR1, SQR2, SQR3, SQR4 101 Convert SQR0, SQR1, SQR2, SQR3, SQR4, SQR5 110 Convert SQR0, SQR1, SQR2, SQR3, SQR4, SQR5, SQR6 111 Convert SQR0, SQR1, SQR2, SQR3, SQR4, SQR5, SQR6, SQR7

Table 22-6 Sequence configuration to be converted

In this mode, whether the ADC is started through the software START bit or an external trigger, once the ADC is started, it will continue to convert the selected conversion sequence until the ADC\_START.START bit is cleared to 0, and the conversion will not stop.

After each ADC conversion is completed, the ADC\_ISR.EOC flag is automatically set to 1, and the conversion result is stored in the conversion result registers ADC\_RESULT0~ADC\_RESULT7 with the same sequence number as the sequence SQR0~SQR7. When all conversions of the selected conversion sequence are completed, the sequence conversion completion flag ADC\_ISR.EOS is set to 1. The user should read the conversion result in time to avoid overflow of the conversion result. User clears ADC\_START.START bit to 0 to stop conversion.

Taking the sequence conversion SQR0~SQR3 as an example, the sequence of the sequence continuous conversion mode is shown in the following figure:



Figure 22-6 Sequence continuous conversion timing diagram

The ADC sequence continuous conversion is started by the START bit, and the reference operation flow is as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.ADC to 1, enable the GPIO clock corresponding to the ADC channel, the GPIO clock corresponding to the external reference voltage pin, and the ADC working clock;
- Step 2: Set the GPIO pin corresponding to the ADC channel to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set the GPIO pin corresponding to the external reference voltage to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;

### Caution:

If the ADC reference voltage does not select the external reference voltage pin, skip this step.

- Step 4: Set ADC\_CR0.EN to 1 to enable ADC module;
- Step 5: Query and wait for the ADC\_ISR.READY bit to become 1, and wait for the ADC module to start up;
- Step 6: Set ADC\_CR0.MODE to 3, select sequential continuous conversion mode;
- Step 7: Configure ADC\_CR0.REF and select the reference voltage of ADC;
- Step 8: Configure ADC\_CRO. SAM and ADC\_CRO. CLK, set ADC sampling speed and clock selection;
- Step 9: Configure ADC\_SQR0.ENS, select the sequence to be converted, as shown in *Figure 22-6*, set ADC\_SQR0.ENS to 3, and the conversion sequence to be SQR0~SQR3;
- Step 10: Configure ADC\_SQR0.SQR0, select the channel to be converted for the sequence SQR0 to be converted, as shown in *Figure 22-6*, set ADC\_SQR0.SQR0 to 3, and the channel to be converted for the sequence SQR0 to AIN3;
- Step 11: Configure ADC\_SQR0.SQR1, select the channel to be converted for the sequence SQR1 to be converted, as shown in *Figure 22-6*, set ADC\_SQR0.SQR1 to 5, and the channel to be converted for the sequence SQR1 to AIN5;
- Step 12: Configure ADC\_SQR0.SQR2, select the channel to be converted of the sequence SQR2 to be converted, as shown in *Figure 22-6*, set ADC\_SQR0.SQR2 to 0, and the channel to be converted of the sequence SQR2 to AINO;



- Step 13: Configure ADC\_SQR0.SQR3, select the channel to be converted of the sequence SQR3 to be converted, as shown in *Figure 22-6*, set ADC\_SQR0.SQR3 to 2, and the channel to be converted of the sequence SQR3 to AIN2;
- Step 14: Set ADC\_ICR to 0, clear ADC interrupt flag;
- Step 15: Set ADC\_START.START to 1 to start ADC conversion;
- Step 16: Query and wait for ADC\_ISR.EOS to become 1, and read the ADC\_RESULT0~ADC\_RESULT3 registers in sequence to obtain the ADC conversion results of each channel. When ADC\_ISR.EOS is 1, it means that a sequence conversion of 4 channels is completed;
- Step 17: Set ADC\_START.START to 0 to stop ADC conversion;
- Step 18: If you need to convert other channels, repeat steps 9 to 18;
- Step 19: Set ADC\_CR0.EN to 0 to turn off the ADC module.

### 22.5.5 Sequence scan conversion mode (MODE=4)

The difference between the sequence scan conversion mode and the sequence continuous conversion is that the sequence scan conversion mode only completes the conversion of the selected sequence once.

In this mode, whether the ADC is started through the software START bit or an external trigger, starting the ADC once will convert all the selected conversion sequences once.

After each ADC conversion is completed, the ADC\_ISR.EOC flag is automatically set to 1, and the conversion result is stored in the conversion result registers ADC\_RESULT0~ADC\_RESULT7 with the same serial number as the sequence SQR0~SQR7. When all conversions of the selected conversion sequence are completed, the ADC\_ISR.EOS flag becomes 1, the ADC\_START.START bit is automatically cleared to 0, and the ADC stops converting.

Taking the sequence conversion SQR0~SQR3 as an example, the sequence of the sequence continuous conversion mode is shown in the following figure:



Figure 22-7 Sequence scan conversion timing diagram

- The ADC sequence scan conversion is started by the START bit, and the reference operation flow is as follows:
- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.ADC to 1, enable the GPIO clock corresponding to the ADC channel, the GPIO clock corresponding to the external reference voltage pin, and the ADC working clock;
- Step 2: Set the GPIO pin corresponding to the ADC channel to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set the GPIO pin corresponding to the external reference voltage to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;

#### Caution:

If the ADC reference voltage does not select the external reference voltage pin, skip this step.

- Step 4: Set ADC\_CR0.EN to 1 to enable ADC module;
- Step 5: Query and wait for the ADC\_ISR.READY bit to become 1, and wait for the ADC module to start up;
- Step 6: Set ADC\_CR0.MODE to 4, select sequence scan conversion mode;
- **Step 7:** Configure ADC\_CRO.REF and select the reference voltage of ADC;
- Step 8: Configure ADC\_CR0. SAM and ADC\_CR0. CLK, set ADC sampling speed and clock selection;
- Step 9: Configure ADC\_SQR0.ENS, select the sequence to be converted, as shown in *Figure 22-7*, set ADC\_SQR0.ENS to 3, and the conversion sequence to be SQR0~SQR3;
- Step 10: Configure ADC\_SQR0.SQR0, select the channel to be converted for the sequence SQR0 to be converted, as shown in *Figure 22-7*, set ADC\_SQR0.SQR0 to 3, and the channel to be converted for the sequence SQR0 to AIN3;
- Step 11: Configure ADC\_SQR0.SQR1, select the channel to be converted for the sequence SQR1 to be converted, as shown in *Figure 22-7*, set ADC\_SQR0.SQR1 to 5, and the channel to be converted for the sequence SQR1 to AIN5;
- Step 12: Configure ADC\_SQR0.SQR2, select the channel to be converted of the sequence SQR2 to be converted, as shown in *Figure 22-7*, set ADC\_SQR0.SQR2 to 0, and the channel to be converted of the sequence SQR2 to AINO;
- Step 13: Configure ADC\_SQR0.SQR3, select the channel to be converted for the sequence SQR3 to be converted, as shown in *Figure 22-7*, set ADC\_SQR0.SQR3 to 2, and the channel to be converted for the sequence SQR3 to AIN2;
- Step 14: Set ADC\_ICR to 0, clear ADC interrupt flag;
- Step 15: Set ADC\_START.START to 1 to start ADC conversion;
- Step 16: Wait for ADC\_ISR.EOS to become 1, and read the ADC\_RESULT0~ADC\_RESULT3 registers in sequence to obtain the ADC conversion result of the corresponding channel. When ADC\_ISR.EOS becomes 1, it means that a sequence conversion of 4 channels is completed, the ADC\_START.START bit is automatically cleared to 0, and the ADC conversion stops;
- Step 17: If you need to convert other channels, repeat steps 9 to 17;
- Step 18: Set ADC\_CR0.EN to 0 to turn off the ADC module.



## 22.5.6 Sequence multiple conversion mode (MODE=5)

The difference between the sequence multiple conversion mode and the sequence scan conversion mode is that the sequence scan conversion mode only completes the conversion of the selected sequence once, while the sequence multiple conversion mode is continuously converted multiple times. The sequence conversion times are determined by the ADC\_CR2.CNT bit field. value, the default conversion times is 1.

In multiple conversion mode, the accumulation conversion function must be enabled, that is, set ADC\_CR2. ACCRST to 1 to clear the ADC\_RESULTACC register. At the same time, set ADC\_CR2.ACCEN to 1 to enable the automatic accumulation function of ADC conversion results.

In this mode, whether the ADC is started by the software START bit or an external trigger, once the ADC is started, the selected conversion sequence will continue to be converted in turn, and the conversion will not stop until the sequence conversion times of the ADC\_CR2.CNT bit value is reached.

After each ADC conversion is completed, the ADC\_ISR.EOC flag is automatically set to 1, and the conversion result is stored in the conversion result registers ADC\_RESULT0~ADC\_RESULT3 with the same serial number as the sequence SQR0~SQR3. At the same time, the conversion result is automatically accumulated, and the accumulated value is stored in the ADC\_RESULTACC register. When all the conversions of the selected conversion sequence are completed, the ADC\_ISR.EOS flag becomes 1. If the sequence conversion times set by the ADC\_CR2.CNT bit field value is not reached, the conversion will continue. The user should read the conversion result in time to avoid overflow of the conversion result.

When the number of sequence conversions reaches the ADC\_CR2.CNT bit value, the ADC\_ISR.EOA flag bit is set to 1, the ADC\_START.START bit is automatically cleared to 0, and the ADC conversion stops.

Taking the sequence conversion SQR0~SQR3 as an example, the sequence of the sequence multiple conversion mode is shown in the following figure, where ADC\_CR2.CNT is 10, and the number of conversions is 11.



Figure 22-8 Sequence multiple conversion timing diagram

483 / 572

The ADC sequence multiple conversions are started through the START bit, and the reference operation flow is as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.ADC to 1, enable the GPIO clock corresponding to the ADC channel, the GPIO clock corresponding to the external reference voltage pin, and the ADC working clock;
- Step 2: Set the GPIO pin corresponding to the ADC channel to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set the GPIO pin corresponding to the external reference voltage to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;

#### Caution:

If the ADC reference voltage does not select the external reference voltage pin, skip this step.

- Step 4: Set ADC\_CR0.EN to 1 to enable ADC module;
- Step 5: Query and wait for the ADC\_ISR.READY bit to become 1, and wait for the ADC module to start up;
- Step 6: Set ADC\_CR0.MODE to 5, select sequence multiple conversion mode;
- Step 7: Configure ADC\_CR0.REF and select the reference voltage of ADC;
- Step 8: Configure ADC\_CR0. SAM and ADC\_CR0. CLK, set ADC sampling speed and clock selection;
- Step 9: Configure ADC\_SQR0.ENS, select the sequence to be converted, as shown in *Figure 22-8*, set ADC\_SQR0.ENS to 3, and the conversion sequence to be SQR0~SQR3;
- Step 10: Configure ADC\_SQR0.SQR0, select the channel to be converted of the sequence SQR0 to be converted, as shown in *Figure 22-8*, set ADC\_SQR0.SQR0 to 3, and the channel to be converted of SQR0 to AlN3;
- Step 11: Configure ADC\_SQR0.SQR1, select the channel to be converted of the sequence SQR1 to be converted, as shown in *Figure 22-8*, set ADC\_SQR0.SQR1 to 5, and the channel to be converted of SQR1 to AIN5;
- Step 12: Configure ADC\_SQR0.SQR2, select the channel to be converted of the sequence SQR2 to be converted, as shown in *Figure 22-8*, set ADC\_SQR0.SQR2 to 0, and the channel to be converted of SQR2 to AIN0;
- Step 13: Configure ADC\_SQR0.SQR3, select the channel to be converted of the sequence SQR3 to be converted, as shown in *Figure 22-8*, set ADC\_SQR0.SQR3 to 2, and the channel to be converted of SQR3 to AIN2;
- Step 14: Configure ADC\_CR2.CNT, as shown in *Figure 22-8*, set ADC\_CR2.CNT to 10, then the number of conversions is 11;
- **Step 15:** Set ADC\_CR2.ACCRST and ADC\_CR2.ACCEN to 1 to enable the conversion result accumulation function;
- Step 16: Set ADC\_ICR to 0, clear ADC interrupt flag;
- Step 17: Set ADC\_START.START to 1 to start ADC conversion;
- Step 18: Wait for ADC\_ISR.EOS to become 1 in a loop, and continuously read the ADC\_RESULT0~ADC\_RESULT3 registers in turn to obtain the ADC conversion result of the corresponding channel. When ADC\_ISR. EOS is 1, it means that a sequence conversion of 4 channels is completed;
- Step 19: Wait for ADC\_ISR.EOA to become 1 in a loop, and continuously read ADC\_RESULT0~ADC\_RESULT3 registers in turn to obtain ADC conversion results. When ADC\_ISR.EOA is 1, it means that multiple conversions are completed, the ADC\_START.START bit is automatically cleared to 0, and the ADC conversion stops;
- Step 20: If you need to convert other channels, repeat steps 9 to 19;
- Step 21: Set ADC\_CR0.EN to 0 to turn off the ADC module.



484 / 572 Rev 1.0

### 22.5.7 Sequence intermittent conversion mode (MODE=6)

In sequence intermittent conversion mode, each time the ADC is turned on, only the current sequence is converted, not all sequences selected.

In this mode, the ADC can be started via the software START bit, or an external trigger can be selected to start.

Each time the ADC is started, an ADC conversion is performed for the specified channel in the current ADC conversion sequence SQRy (y=0~7). The ADC conversion is completed, the ADC\_ISR.EOC flag is automatically set to 1, and the conversion result is stored in the corresponding ADC\_RESULTy (y=0~7). At the same time, the ADC\_START.START bit is automatically cleared to 0, and the ADC conversion is completed. Waiting for the ADC conversion to start again.

When the ADC is restarted next time, the channel to be converted is automatically switched to the designated channel of the next conversion sequence SQR(y+1), and the ADC conversion is performed again. If the currently completed conversion sequence is SQR7, the next sequence to be converted is automatically reset to SQR0.

The ADC\_ISR.EOS flag becomes 1 when all channels of the conversion sequence SQRy are converted.

Taking the sequence conversion SQR0~SQR3 as an example, the sequence of the sequence intermittent conversion mode is shown in the following figure:



Figure 22-9 Sequence intermittent conversion timing diagram

The ADC sequence intermittent conversion is started by the START bit, and the reference operation flow is as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.ADC to 1, enable the GPIO clock corresponding to the ADC channel, the GPIO clock corresponding to the external reference voltage pin, and the ADC working clock;
- Step 2: Set the GPIO pin corresponding to the ADC channel to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;
- Step 3: Set the GPIO pin corresponding to the external reference voltage to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;

### Caution:

If the ADC reference voltage does not select the external reference voltage pin, skip this step.

Step 4: Set ADC\_CR0.EN to 1 to enable ADC module;



- Step 5: Query and wait for the ADC\_ISR.READY bit to become 1, and wait for the ADC module to start up;
- Step 6: Set ADC\_CR0.MODE to 6, and select sequence intermittent conversion mode;
- Step 7: Configure ADC\_CRO.REF and select the reference voltage of ADC;
- Step 8: Configure ADC\_CR0. SAM and ADC\_CR0. CLK, set ADC sampling speed and clock selection;
- Step 9: Configure ADC\_SQR0.ENS, select the sequence to be converted, as shown in *Figure 22-9*, set ADC\_SQR0.ENS to 3, and the conversion sequence to be SQR0~SQR3;
- Step 10: Configure ADC\_SQR0.SQR0, select the channel to be converted of the sequence SQR0 to be converted, as shown in *Figure 22-9*, set ADC\_SQR0.SQR0 to 3, and the channel to be converted of the sequence SQR0 to AIN3;
- Step 11: Configure ADC\_SQR0.SQR1, select the channel to be converted of the sequence SQR1 to be converted, as shown in *Figure 22-9*, set ADC\_SQR0.SQR1 to 5, and the channel to be converted of the sequence SQR1 to AIN5;
- Step 12: Configure ADC\_SQR0.SQR2, select the channel to be converted of the sequence SQR2 to be converted, as shown in *Figure 22-9*, set ADC\_SQR0.SQR2 to 0, and the channel to be converted of the sequence SQR2 to AINO;
- Step 13: Configure ADC\_SQR0.SQR3, select the channel to be converted of the sequence SQR3 to be converted, as shown in *Figure 22-9*, set ADC\_SQR0.SQR3 to 2, and the channel to be converted of the sequence SQR3 to AIN2;
- Step 14: Set ADC\_ICR to 0, clear ADC interrupt flag;
- Step 15: Set ADC\_START.START to 1 to start ADC conversion;
- Step 16: Wait for ADC\_ISR.EOC to become 1, and choose to read the ADC\_RESULTO register to obtain the ADC conversion result of the channel specified by the conversion sequence SQRO;
- Step 17: Set ADC\_START.START to 1 to start ADC conversion again;
- Step 18: Wait for ADC\_ISR.EOC to become 1, and choose to read the ADC\_RESULT1 register to obtain the ADC conversion result of the channel specified by the conversion sequence SQR1;
- Step 19: Set ADC\_START.START to 1 to start ADC conversion again;
- Step 20: Wait for ADC\_ISR.EOC to become 1, and choose to read the ADC\_RESULT2 register to obtain the ADC conversion result of the channel specified by the conversion sequence SQR2;
- Step 21: Set ADC\_START.START to 1 and start ADC conversion again;
- Step 22: Wait for ADC\_ISR.EOC to become 1, and choose to read the ADC\_RESULT3 register to get the ADC conversion result for the channel specified by conversion sequence SQR3. When ADC\_ISR.EOS is 1, it means that a sequence conversion of 4 channels is completed;
- Step 23: Repeat steps 15 to 22 to continue ADC conversion; if you need to convert other channels, repeat steps 8 to 22;
- Step 24: Set ADC\_CR0.EN to 0 to turn off the ADC module.

### 22.6 Accumulation conversion function

The accumulation conversion function can be performed in any working mode of the ADC. And in the multiple conversion mode, the cumulative conversion function must be enabled.

Set ADC\_CR2.ACCEN to 1 to enable the automatic accumulation function of ADC conversion results. Each time the ADC completes a channel conversion, it automatically accumulates the conversion results, and the accumulated value is stored in the ADC\_RESULTACC register.

Before using the accumulation function, the ADC\_RESULTACC register must be cleared first. Setting ADC\_CR2. ACCRST to 1 can clear the ADC\_RESULTACC register to 0.

*Figure 22-10 Accumulation conversion timing diagram* demonstrates the process of 10 consecutive conversion accumulations for the three channels of AIN0, AIN1, and AIN5. It is assumed that the ADC conversion results of AIN0, AIN1, and AIN5 are 0x010, 0x020, and 0x040 in sequence.

Set ADC\_START.START to 1 to start the ADC, and the state machine inside the ADC will convert AIN0, AIN1, and AIN5 in turn, and the ADC conversion will not stop until the total number of conversions reaches 10. Each time a conversion completes, the ADC\_RESULTACC register automatically accumulates the conversion result.



Figure 22-10 Accumulation conversion timing diagram

The ADC sequence is started for multiple conversions through the START bit, and the conversion results are accumulated. The operation flow is as follows:

- Step 1: Set SYSCTRL\_AHBEN.GPIOx to 1, SYSCTRL\_APBEN2.ADC to 1, enable the GPIO clock corresponding to the ADC channel, the GPIO clock corresponding to the external reference voltage pin, and the ADC working clock;
- Step 2: Set the GPIO pin corresponding to the ADC channel to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;



Step 3: Set the GPIO pin corresponding to the external reference voltage to the analog function. For the specific register configuration, please refer to chapter *9 General-purpose input/output (GPIO)*;

#### Caution:

If the ADC reference voltage does not select the external reference voltage pin, skip this step.

- Step 4: Set ADC\_CR0.EN to 1 to enable ADC module;
- Step 5: Query and wait for the ADC\_ISR.READY bit to become 1, and wait for the ADC module to start up;
- Step 6: Set ADC\_CR0.MODE to 5, select sequence multiple conversion mode;
- **Step 7:** Configure ADC\_CR0.REF and select the reference voltage of ADC;
- Step 8: Configure ADC\_CR0. SAM and ADC\_CR0. CLK, set ADC sampling speed and clock selection;
- Step 9: Configure ADC\_CR2.CNT, as shown in *Figure 22-10*, set ADC\_CR2.CNT to 9, then the number of conversions is 10;
- Step 10: Set ADC\_CR2.ACCEN to 1 to enable the automatic accumulation control of ADC conversion results;
- Step 11: Set ADC\_CR2.ACCRST to 1, and the ADC conversion result accumulation register ADC\_RESULTACC is cleared to 0;
- Step 12: Configure ADC\_SQR0.ENS, select the sequence to be converted, as shown in *Figure 22-10*, set ADC\_SQR0.ENS to 2, and the conversion sequence to be SQR0~SQR2;
- Step 13: Configure ADC\_SQR0.SQR0, select the channel to be converted for the sequence SQR0 to be converted, as shown in *Figure 22-10*, set ADC\_SQR0.SQR0 to 0, and the channel to be converted for the sequence SQR0 to AIN0;
- Step 14: Configure ADC\_SQR0.SQR1, select the channel to be converted for the sequence SQR1 to be converted, as shown in *Figure 22-10*, set ADC\_SQR0.SQR1 to 1, and the channel to be converted for the sequence SQR1 to AIN1;
- Step 15: Configure ADC\_SQR0.SQR2, select the channel to be converted of the sequence SQR2 to be converted, as shown in *Figure 22-10*, set ADC\_SQR0.SQR2 to 5, and the channel to be converted of the sequence SQR2 to AIN5;
- Step 16: Set ADC\_IER.EOA to 1 to enable multiple conversion completion interrupts;
- Step 17: Set ADC\_ICR.EOA to 0, clear ADC\_ISR.EOA interrupt flag;
- Step 18: Set ADC\_ICR to 0, clear ADC interrupt flag;
- Step 19: Set ADC\_START.START to 1 to start ADC conversion;
- Step 20: Wait for ADC\_ISR.EOC to become 1 in a loop, and continuously read the ADC\_RESULTACC register to obtain the accumulated value of ADC conversion result. When ADC\_ISR.EOS is 1, it means that a sequence conversion of 3 channels is completed.
- Step 21: Wait for ADC\_ISR.EOA to become 1, while reading the ADC\_RESULTACC register continuously. When ADC\_ISR.EOA is 1, it means that multiple conversions are completed, the ADC\_START.START bit is automatically cleared to 0, and the ADC conversion stops. In this example, when AINO completes the 4th ADC conversion, the ADC conversion stops;
- Step 22: Set ADC\_CR0.EN to 0 to turn off the ADC module.



### 22.7 Auto-off mode

The user can enable the ADC auto-off function by setting ADC\_START.AUTOSTOP to 1. When the specified ADC conversion is completed, the ADC\_CR0.EN bit is automatically cleared to 0, and the ADC function is disabled. If the ADC conversion needs to continue, ADC\_CR0.EN must be reset to 1 to enable the ADC module.

If the single channel single conversion mode is used, when the conversion is completed, the ADC enable is automatically turned off.

If the sequence scan conversion mode is used, when all sequence conversions are completed, the ADC enable is automatically turned off.

If the multiple conversion mode (single channel multiple conversion mode or sequence multiple conversion mode) is used, when the set number of conversions is reached, the ADC conversion stops and the ADC enable is automatically turned off.

If the continuous conversion mode (single channel continuous conversion mode or sequence continuous conversion mode) is used, the ADC enable will not be automatically turned off after the conversion is completed. Setting ADC\_START.START to 0 will turn off continuous conversion and automatically turn off ADC enable.

When using sequence intermittent conversion mode, when all selected channels are converted, the ADC enable is automatically turned off.

## 22.8 External trigger source

ADC conversion can be started either by software (that is, setting ADC\_START.START to 1) or by external trigger. The trigger source is selected by the external trigger register ADC\_TRIGGER. There are 16 ways to trigger the ADC, as shown in the following table:

Table 22-7 ADC conversion external trigger source

| ADC_TRIGGER bit field | Bit field name | Functional description                                      |  |
|-----------------------|----------------|-------------------------------------------------------------|--|
| 24                    | GPIOF          | GPIOF interrupt triggers ADC to start                       |  |
| 21                    | GPIOC          | GPIOC interrupt triggers ADC to start                       |  |
| 20                    | GPIOB          | GPIOB interrupt triggers ADC to start                       |  |
| 19                    | GPIOA          | GPIOA interrupt triggers ADC to start                       |  |
| 15                    | DMA            | DMA interrupt triggers ADC to start                         |  |
| 13                    | I2C            | I2C interrupt triggers ADC to start                         |  |
| 11                    | SPI            | SPI interrupt triggers ADC to start                         |  |
| 10                    | UART3          | UART3 interrupt triggers ADC to start                       |  |
| 9                     | UART2          | UART2 interrupt triggers ADC to start                       |  |
| 8                     | UART1          | UART1 interrupt triggers ADC to start                       |  |
| 7                     | BTIM3          | BTIM3 interrupt triggers ADC to start                       |  |
| 6                     | BTIM2          | BTIM2 interrupt triggers ADC to start                       |  |
| 5                     | BTIM1          | BTIM1 interrupt triggers ADC to start                       |  |
| 2                     | GTIM2          | GTIM2 interrupt triggers ADC to start                       |  |
| 1                     | GTIM1          | GTIM1 interrupt triggers ADC to start                       |  |
| 0                     | ATIM           | The trigger signal output by ATIM triggers the ADC to start |  |

The schematic diagram of the external trigger source for ADC conversion is shown in the following figure:

GPIOF interrupt
ADC\_TRIGGER [24]
GPIOC interrupt
ADC\_TRIGGER [23]

:

External trigger source

GTIM1 interrupt
ADC\_TRIGGER [1]

ATIM output trigger signal
ADC\_TRIGGER [0]

Figure 22-11 Schematic diagram of external trigger source for ADC conversion

## 22.9 Analog watchdog

The analog watchdog function supports the comparison of the ADC conversion result with the threshold set by the user, supports the comparison of upper threshold, lower threshold, and interval value, and sets the comparison threshold through the threshold registers ADC VTH and ADC VTL.

Set the WDTALL bit field of the control register ADC\_CR1 to 1 to enable the analog watchdog, and enable the analog watchdog function of the specified channel through the WDTCH bit field of the ADC\_CR1 register.

The analog watchdog function is often used for automatic monitoring of analog quantities. If the corresponding bit fields (WDTR, WDTH, WDTL) of the interrupt enable register ADC\_IER are set, an interrupt request will be generated when the ADC conversion result meets the user's expectation.

A schematic diagram of the threshold comparison of the analog watchdog is shown in the following figure:



Figure 22-12 Schematic diagram of ADC threshold comparison

Upper threshold comparison: When the conversion result is within the interval [ADC\_VTH, 4095], the ADC\_ISR. WDTH flag bit is set to 1.

Lower threshold comparison: When the conversion result is in the [0, ADC\_VTL) interval, the ADC\_ISR.WDTL flag is set to 1.

Interval value comparison: When the conversion result is in the interval [ADC\_VTL, ADC\_VTH), the ADC\_ISR. WDTR flag is set to 1.

## 22.10 Temperature sensor

CW32W031 has a built-in temperature sensor module. The output voltage of the sensor changes with temperature. Set the sampling channel of the ADC module as an internal temperature sensor, and the current ambient temperature can be calculated through the ADC measurement results.

The temperature sensor is off by default. By setting the TSEN bit field of the control register ADC\_CR0 to 1, the temperature sensor is enabled.

The formula for calculating the ambient temperature is as follows:

Ambient temperature =  $T_0 \times 0.5 + 0.0924 \times V_{ref} \times (AdcValue - Trim)$ 

#### Where:

V<sub>ref</sub> is the reference voltage of the current ADC module, which is 1.5V or 2.5V.

 $T_0$  is the 8-bit initial calibration temperature value, which is recorded in the FLASH memory of the chip. Its address is 0x0001 0A09, and the unit is 0.5 degrees Celsius. The read value needs to be divided by 2 to be the actual temperature.

AdcValue is the ADC conversion result of the ADC module measuring the output voltage of the temperature sensor, and the value range is  $0 \sim 4095$ .

Trim is a 16-bit calibration value, which needs to be read from the FLASH memory of the chip during calculation, and its storage address is shown in the following table:

Table 22-8 ADC calibration value address

| ADC reference voltage | Calibration value storage address | Calibration value accuracy |
|-----------------------|-----------------------------------|----------------------------|
| Internal 1.5V         | 0x0010 0A0A - 0x0010 0A0B         | ±3°C                       |
| Internal 2.5V         | 0x0010 0A0C - 0x0010 0A0D         | ±3°C                       |

A calculation example is as follows:

Condition 1:  $V_{ref}$ =1.5, AdcValue = 0x8CB, Trim = 0x883,  $T_0$  = 0x32

Temperature 1:  $0x32 \times 0.5 + 0.0924 \times 1.5 \times (0x8CB - 0x883) = 35^{\circ}C$ 

Condition 2:  $V_{ref} = 2.5$ , AdcValue = 0x599, Trim = 0x516,  $T_0 = 0x32$ 

Temperature 2:  $0x32 \times 0.5 + 0.0924 \times 2.5 \times (0x599 - 0x516) = 55.3$ °C

The reference operation flow for measuring the ambient temperature through the ADC is as follows:



- Step 1: Set SYSCTRL\_APBEN2.ADC to 1, enable ADC configuration clock and working clock;
- Step 2: Set ADC\_CR0.EN to 1 to enable the ADC module;
- Step 3: Query and wait for the ADC\_ISR.READY bit to become 1, and wait for the ADC module to start up;
- Step 4: Set ADC\_CR0.MODE to 0, select single channel single conversion mode;
- Step 5: Configure ADC\_CRO.REF, select ADC reference voltage as internal 1.5V or internal 2.5V;
- Step 6: Configure ADC\_CRO. SAM and ADC\_CRO. CLK, and set the conversion speed of ADC;
- Step 7: Set ADC\_CR0.TSEN to 1 to enable the temperature sensor;
- Step 8: Set ADC\_CR1.CHMUX to 0x0E, and select the channel to be converted as the voltage output of the temperature sensor;
- Step 9: Set ADC\_CR0.BUF to 1 to enable the built-in follower;
- Step 10: Set ADC\_ICR.EOC to 0, clear ADC\_ISR.EOC flag;
- Step 11: Set ADC\_START.START to 1 to start ADC conversion;
- Step 12: Wait for ADC\_ISR.EOC to become 1, and read the ADC\_RESULT0 register to get the ADC conversion result;
- Step 13: Set ADC\_CR0.EN to 0 and turn off the ADC module;
- Step 14: Read T<sub>0</sub> and Trim, and calculate the current ambient temperature according to the formula.

# 22.11 ADC interrupts

ADC interrupt request, as shown in the following table:

Table 22-9 ADC interrupt sources and interrupt flags

| Interrupt source                           | Interrupt flag bit | Interrupt enable         | Flag clear                   |
|--------------------------------------------|--------------------|--------------------------|------------------------------|
| Conversion result overflow                 | ADC_ISR.OVW        | ADC_IER.OVW is set to 1  | ADC_ICR.OVW is cleared to 0  |
| Conversion result >= ADC_VTL, and< ADC_VTH | ADC_ISR.WDTR       | ADC_IER.WDTR is set to 1 | ADC_ICR.WDTR is cleared to 0 |
| Conversion result >= ADC_VTH               | ADC_ISR.WDTH       | ADC_IER.WDTH is set to 1 | ADC_ICR.WDTH is cleared to 0 |
| Conversion result < ADC_VTL                | ADC_ISR.WDTL       | ADC_IER.WDTL is set to 1 | ADC_ICR.WDTL is cleared to 0 |
| ADC completes multiple conversions         | ADC_ISR.EOA        | ADC_IER.EOA is set to 1  | ADC_ICR.EOA is cleared to 0  |
| ADC sequence conversion completed          | ADC_ISR.EOS        | ADC_IER.EOS is set to 1  | ADC_ICR.EOS is cleared to 0  |
| ADC conversion completed                   | ADC_ISR.EOC        | ADC_IER.EOC is set to 1  | ADC_ICR.EOC is cleared to 0  |

# 22.12 List of registers

ADC base address: ADC\_BASE = 0x4001 2400

Table 22-10 List of ADC registers

| Register name | Register address | Register description                              |
|---------------|------------------|---------------------------------------------------|
| ADC_CR0       | ADC_BASE + 0x00  | ADC control register 0                            |
| ADC_CR1       | ADC_BASE + 0x04  | ADC control register 1                            |
| ADC_START     | ADC_BASE + 0x08  | ADC startup register                              |
| ADC_CR2       | ADC_BASE + 0x10  | ADC control register2                             |
| ADC_VTH       | ADC_BASE + 0x14  | ADC high threshold register                       |
| ADC_VTL       | ADC_BASE + 0x18  | ADC low threshold register                        |
| ADC_TRIGGER   | ADC_BASE + 0x1C  | ADC external trigger register                     |
| ADC_RESULT0   | ADC_BASE + 0x20  | ADC conversion result 0 register                  |
| ADC_RESULT1   | ADC_BASE + 0x24  | ADC conversion result 1 register                  |
| ADC_RESULT2   | ADC_BASE + 0x28  | ADC conversion result 2 register                  |
| ADC_RESULT3   | ADC_BASE + 0x2C  | ADC conversion result 3 register                  |
| ADC_RESULT4   | ADC_BASE + 0x30  | ADC conversion result 4 register                  |
| ADC_RESULT5   | ADC_BASE + 0x34  | ADC conversion result 5 register                  |
| ADC_RESULT6   | ADC_BASE + 0x38  | ADC conversion result 6 register                  |
| ADC_RESULT7   | ADC_BASE + 0x3C  | ADC conversion result 7 register                  |
| ADC_RESULTACC | ADC_BASE + 0x40  | ADC conversion result accumulation value register |
| ADC_IER       | ADC_BASE + 0x44  | ADC interrupt enable register                     |
| ADC_ICR       | ADC_BASE + 0x48  | ADC interrupt flag clear register                 |
| ADC_ISR       | ADC_BASE + 0x4C  | ADC interrupt flag register                       |
| ADC_SQR0      | ADC_BASE + 0x50  | ADC sequence configuration register 0             |
| ADC_SQR1      | ADC_BASE + 0x54  | ADC sequence configuration register 1             |

# 22.13 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

## 22.13.1 ADC\_CR0 control register 0

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 15:14     | BIAS | RW         | Please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 13        | BUF  | RW         | Built-in follower enable control 0: Turn off the follower, the external input signal is directly connected to the ADC 1: Turn on the follower, the external input signal is connected to the ADC after passing through the follower Caution 1: When this function is enabled, the maximum conversion speed is 200K SPS Caution 2: The following conditions must enable this function: The output impedance of the signal to be converted is relatively high; the signal to be converted is VDDA/3, the output voltage of the built-in temperature sensor, and the output voltage of the internal reference 1.2V. |  |
| 12:11     | SAM  | RW         | ADC sampling cycle selection 00: 5 ADCCLK clock cycles 01: 6 ADCCLK clock cycles 10: 8 ADCCLK clock cycles 11: 10 ADCCLK clock cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 10:8      | CLK  | RW         | ADC working clock configuration 000: PCLK 100: PCLK / 16 001: PCLK / 2 101: PCLK / 32 010: PCLK / 4 110: PCLK / 64 011: PCLK / 8 111: PCLK / 128                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 7:6       | REF  | RW         | ADC reference voltage selection 00: Built-in 1.5V reference voltage 01: Built-in 2.5V reference voltage 10: External reference voltage ExRef 11: VDDA supply voltage                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| 5         | TSEN | RW         | Built-in temperature sensor enable control 0: Built-in temperature sensor disabled 1: Built-in temperature sensor enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| 4         | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1       | MODE | RW         | ADC operating mode configuration 000: Single channel single conversion mode 001: Single channel multiple conversion mode, see CR2. CNT for the number of conversions 010: Single channel continuous conversion mode 011: Sequence continuous conversion mode 100: Sequence scan conversion mode 101: Sequence multiple conversion mode, see CR2.CNT for the number of conversions 110: Sequence intermittent conversion mode |
| 0         | EN   | RW         | ADC enable control 0: ADC disabled 1: ADC enabled Caution: After enabling ADC, you should wait for ISR. READY to become 1 before performing ADC conversion.                                                                                                                                                                                                                                                                  |

## 22.13.2 ADC\_CR1 control register 1

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|-----------|----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:16     | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 15        | DMASOCEN | RW         | One conversion completes DMA trigger signal enable control 0: No function 1: ADC triggers DMA every time conversion is complete                                                                                                                                                                                                                                                                                                   |  |
| 14        | DMASOFEN | RW         | Sequence conversion complete DMA trigger signal enable control 0: No function 1: Trigger DMA when ADC sequence conversion is complete                                                                                                                                                                                                                                                                                             |  |
| 13        | WDTALL   | RW         | All channels analog watchdog enable control 0: Analog watchdog disabled 1: Analog watchdog enabled                                                                                                                                                                                                                                                                                                                                |  |
| 12        | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 11:8      | WDTCH    | RW         | Single channel analog watchdog enable configuration         0000: AIN0       1000: AIN8         0001: AIN1       1001: AIN9         0010: AIN2       1010: AIN10         0011: AIN3       1011: AIN11         0100: AIN4       1100: AIN12         0101: AIN5       1101: VDDA/3         0110: AIN6       1110: TS built-in temperature sensor         0111: AIN7       1111: 1.2V core voltage reference source                  |  |
| 7         | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 6         | ALIGN    | RW         | ADC conversion result alignment 0: Right justified, the conversion result is stored in [11:0] 1: Left justified, conversion result is stored in [15:4]                                                                                                                                                                                                                                                                            |  |
| 5         | DISCARD  | RW         | Single channel ADC conversion result saving strategy configuration 0: Overwrite old data that has not been read, keep new data 1: Discard the newly converted data, keep the unread old data                                                                                                                                                                                                                                      |  |
| 4         | RFU      | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 3:0       | CHMUX    | RW         | Single channel conversion mode to be converted channel configuration         0000: AIN0       1000: AIN8         0001: AIN1       1001: AIN9         0010: AIN2       1010: AIN10         0011: AIN3       1011: AIN11         0100: AIN4       1100: AIN12         0101: AIN5       1101: VDDA/3         0110: AIN6       1110: TS built-in temperature sensor         0111: AIN7       1111: 1.2V core voltage reference source |  |

## 22.13.3 ADC\_CR2 control register 2

Address offset: 0x10 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                              |
|-----------|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10     | RFU    | -          | Reserved bits, please keep the default value                                                                                                      |
| 9         | ACCRST | R0W1       | The accumulated value register is cleared to 0 0: No function 1: The conversion result accumulation value register ADC_ RESULTACC is cleared to 0 |
| 8         | ACCEN  | RW         | Conversion result accumulation enabled 0: Accumulation function disabled 1: Accumulation function enabled                                         |
| 7:0       | CNT    | RW         | Configuration of the number of conversions in multiple conversion mode The number of conversions is CNT+1                                         |

## 22.13.4 ADC\_SQR0 sequence configuration register 0

Address offset: 0x50 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                  |
| 18:16     | ENS  | RW         | Sequence configuration to convert  000: Convert SQR0 100: Convert SQR0-SQR4  001: Convert SQR0-SQR1 101: Convert SQR0-SQR5  010: Convert SQR0-SQR2 110: Convert SQR0-SQR6  011: Convert SQR0-SQR3 111: Convert SQR0-SQR7                                                                                                                                                                                      |
| 15:12     | SQR3 | RW         | Sequence 3 channel configuration to be converted See SQR0 for details                                                                                                                                                                                                                                                                                                                                         |
| 11:8      | SQR2 | RW         | Sequence 2 channel configuration to be converted See SQR0 for details                                                                                                                                                                                                                                                                                                                                         |
| 7:4       | SQR1 | RW         | Sequence 1 channel configuration to be converted<br>See SQR0 for details                                                                                                                                                                                                                                                                                                                                      |
| 3:0       | SQR0 | RW         | Sequence 0 Channel configuration to be converted         0000: AIN0       1000: AIN8         0001: AIN1       1001: AIN9         0010: AIN2       1010: AIN10         0011: AIN3       1011: AIN11         0100: AIN4       1100: AIN12         0101: AIN5       1101: VDDA/3         0110: AIN6       1110: TS built-in temperature sensor         0111: AIN7       1111: 1.2V core voltage reference source |



## 22.13.5 ADC\_SQR1 sequence configuration register 1

Address offset: 0x54 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU  | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                  |
| 15:12     | SQR7 | RW         | Sequence 7 channel configuration to be converted See SQR4 for details                                                                                                                                                                                                                                                                                                                                         |
| 11:8      | SQR6 | RW         | Sequence 6 channel configuration to be converted See SQR4 for details                                                                                                                                                                                                                                                                                                                                         |
| 7:4       | SQR5 | RW         | Sequence 5 channel configuration to be converted<br>See SQR4 for details                                                                                                                                                                                                                                                                                                                                      |
| 3:0       | SQR4 | RW         | Sequence 4 Channel configuration to be converted         0000: AIN0       1000: AIN8         0001: AIN1       1001: AIN9         0010: AIN2       1010: AIN10         0011: AIN3       1011: AIN11         0100: AIN4       1100: AIN12         0101: AIN5       1101: VDDA/3         0110: AIN6       1110: TS built-in temperature sensor         0111: AIN7       1111: 1.2V core voltage reference source |

## 22.13.6 ADC\_VTH high threshold register

Address offset: 0x14 Reset value: 0x0000 0FFF

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:12     | RFU  | -          | Reserved bits, please keep the default value |
| 11:0      | VTH  | RW         | Analog watchdog detects high threshold       |

## 22.13.7 ADC\_VTL low threshold register

Address offset: 0x18 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                         |
|-----------|------|------------|----------------------------------------------|
| 31:12     | RFU  | -          | Reserved bits, please keep the default value |
| 11:0      | VTL  | RW         | Analog watchdog detects low threshold        |



## 22.13.8 ADC\_TRIGGER external trigger register

Address offset: 0x1C Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                       |
|-----------|-------|------------|------------------------------------------------------------|
| 31:25     | RFU   | -          | Reserved bits, please keep the default value               |
| 24        | GPIOF | RW         | GPIOF interrupt triggers ADC startup 0: Disable 1: Enable  |
| 23:22     | RFU   | -          | Reserved bits, please keep the default value               |
| 21        | GPIOC | RW         | GPIOC interrupt triggers ADC startup 0: Disable 1: Enable  |
| 20        | GPIOB | RW         | GPIOB interrupt triggers ADC startup 0: Disable 1: Enable  |
| 19        | GPIOA | RW         | GPIOA interrupt triggers ADC startup 0: Disable 1: Enable  |
| 18:16     | RFU   | -          | Reserved bits, please keep the default value               |
| 15        | DMA   | RW         | DMA interrupt triggers ADC to start 0: Disable 1: Enable   |
| 14        | RFU   | -          | Reserved bits, please keep the default value               |
| 13        | I2C   | RW         | I2C interrupt triggers ADC to start 0: Disable 1: Enable   |
| 12        | RFU   | -          | Reserved bits, please keep the default value               |
| 11        | SPI   | RW         | SPI interrupt triggers ADC to start 0: Disable 1: Enable   |
| 10        | UART3 | RW         | UART3 interrupt triggers ADC to start 0: Disable 1: Enable |
| 9         | UART2 | RW         | UART2 interrupt triggers ADC to start 0: Disable 1: Enable |
| 8         | UART1 | RW         | UART1 interrupt triggers ADC to start 0: Disable 1: Enable |

| Bit field | Name  | Permission | Function description                                                             |
|-----------|-------|------------|----------------------------------------------------------------------------------|
| 7         | BTIM3 | RW         | BTIM3 interrupt triggers ADC to start<br>0: Disable<br>1: Enable                 |
| 6         | BTIM2 | RW         | BTIM2 interrupt triggers ADC to start<br>0: Disable<br>1: Enable                 |
| 5         | BTIM1 | RW         | BTIM1 interrupt triggers ADC to start<br>0: Disable<br>1: Enable                 |
| 4:3       | RFU   | -          | Reserved bits, please keep the default value                                     |
| 2         | GTIM2 | RW         | GTIM2 interrupt triggers ADC to start<br>0: Disable<br>1: Enable                 |
| 1         | GTIM1 | RW         | GTIM1 interrupt triggers ADC to start 0: Disable 1: Enable                       |
| 0         | ATIM  | RW         | The trigger signal output by ATIM triggers the ADC to start 0: Disable 1: Enable |

# 22.13.9 ADC\_START start register

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name     | Permission | Function description                                                                                                                                                |
|-----------|----------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2      | RFU      | -          | Reserved bits, please keep the default value                                                                                                                        |
| 1         | AUTOSTOP | RW         | ADC auto disable configuration 0: Continue to keep CR0.EN at 1 after the conversion is completed 1: Automatically set CR0.EN to 0 after the conversion is completed |
| 0         | START    | RW         | ADC start conversion control 0: Stop ADC conversion 1: Start ADC conversion                                                                                         |

## 22.13.10 ADC\_IER interrupt enable register

Address offset: 0x44 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                            |
|-----------|------|------------|---------------------------------------------------------------------------------|
| 31:7      | RFU  | -          | Reserved bits, please keep the default value                                    |
| 6         | OVW  | RW         | Conversion result overflow interrupt enable control 0: Disabled 1: Enabled      |
| 5         | WDTR | RW         | Analog watchdog interval interrupt enable control 0: Disabled 1: Enabled        |
| 4         | WDTH | RW         | Analog watchdog upper threshold interrupt enable control 0: Disabled 1: Enabled |
| 3         | WDTL | RW         | Analog watchdog lower threshold interrupt enable control 0: Disabled 1: Enabled |
| 2         | EOA  | RW         | Multiple conversion complete interrupt enable control 0: Disabled 1: Enabled    |
| 1         | EOS  | RW         | Sequence conversion complete interrupt enable control 0: Disabledd 1: enable    |
| 0         | EOC  | RW         | Conversion complete interrupt enable control 0: Disabled 1: Enabled             |

# 22.13.11 ADC\_ISR interrupt flag register

Address offset: 0x4C Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                                                                                                                |
|-----------|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8      | RFU   | -          | Reserved bits, please keep the default value                                                                                                                        |
| 7         | READY | RO         | Analog circuit initialization complete flag  0: Initialization not completed  1: Initialization has been completed, and ADC conversion can be started               |
| 6         | OVW   | RO         | Conversion result overflow flag 0: The event did not occur 1: A new conversion is completed before the data in the result register has been read                    |
| 5         | WDTR  | RO         | Analog watchdog interval flag  0: The conversion result is outside the range of [ADC_VTL, ADC_VTH)  1: The conversion result is in the range of [ADC_VTL, ADC_VTH)  |
| 4         | WDTH  | RO         | Analog watchdog upper threshold flag  0: The conversion result is outside the range of [ADC_VTH, 4096)  1: The conversion result is in the interval [ADC_VTH, 4096) |
| 3         | WDTL  | RO         | Analog watchdog lower threshold flag  0: The conversion result is outside the range [0, ADC_VTL)  1: The conversion result is in the interval [0, ADC_VTL)          |
| 2         | EOA   | RO         | Multiple conversion complete flag 0: Multiple conversions are not completed 1: Multiple conversions completed                                                       |
| 1         | EOS   | RO         | Sequence conversion complete flag 0: Sequence conversion not completed 1: Sequence conversion completed                                                             |
| 0         | EOC   | RO         | Conversion complete flag 0: One ADC conversion is not completed 1: One ADC conversion has been completed                                                            |

# 22.13.12 ADC\_ICR interrupt flag clear register

Address offset: 0x48 Reset value: 0x0000 007F

| Bit field | Name | Permission | Function description                                                                                                                |  |  |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:7      | RFU  | -          | - Reserved bits, please keep the default value                                                                                      |  |  |
| 6         | OVW  | R1W0       | The conversion result overflow flag is cleared to 0 control W0: The corresponding flag in the ISR register cleared W1: No function  |  |  |
| 5         | WDTR | R1W0       | Analog watchdog interval flag is cleared to 0 control W0: The corresponding flag in the ISR register cleared W1: No function        |  |  |
| 4         | WDTH | R1W0       | Analog watchdog upper threshold flag is cleared to 0 control W0: The corresponding flag in the ISR register cleared W1: No function |  |  |
| 3         | WDTL | R1W0       | Analog watchdog lower threshold flag is cleared to 0 control W0: The corresponding flag in the ISR register cleared W1: No function |  |  |
| 2         | EOA  | R1W0       | Multiple conversion completion flag is cleared to 0 control W0: The corresponding flag in the ISR register cleared W1: No function  |  |  |
| 1         | EOS  | R1W0       | Sequence conversion complete flag is cleared to 0 control W0: The corresponding flag in the ISR register cleared W1: No function    |  |  |
| 0         | EOC  | R1W0       | Conversion complet flag is cleared to 0 control W0: The corresponding flag in the ISR register cleared W1: No function              |  |  |

# 22.13.13 ADC\_RESULT0 conversion result 0 register

Address offset: 0x20 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                         |  |
|-----------|--------|------------|----------------------------------------------|--|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value |  |
| 15:0      | RESULT | RO         | ADC conversion result 0 register             |  |

# 22.13.14 ADC\_RESULT1 conversion result 1 register

Address offset: 0x24 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                         |  |
|-----------|--------|------------|----------------------------------------------|--|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value |  |
| 15:0      | RESULT | RO         | ADC conversion result 1 register             |  |

# 22.13.15 ADC\_RESULT2 conversion result 2 register

Address offset: 0x28 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                         |  |
|-----------|--------|------------|----------------------------------------------|--|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value |  |
| 15:0      | RESULT | RO         | ADC conversion result 2 register             |  |

# 22.13.16 ADC\_RESULT3 conversion result 3 register

Address offset: 0x2C Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                         |  |
|-----------|--------|------------|----------------------------------------------|--|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value |  |
| 15:0      | RESULT | RO         | ADC conversion result 3 register             |  |

# 22.13.17 ADC\_RESULT4 conversion result 4 register

Address offset: 0x30 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                         |  |
|-----------|--------|------------|----------------------------------------------|--|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value |  |
| 15:0      | RESULT | RO         | ADC conversion result 4 register             |  |

# 22.13.18 ADC\_RESULT5 conversion result 5 register

Address offset: 0x34 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                         |
|-----------|--------|------------|----------------------------------------------|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value |
| 15:0      | RESULT | RO         | ADC conversion result 5 register             |



# 22.13.19 ADC\_RESULT6 conversion result 6 register

Address offset: 0x38 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                         |  |
|-----------|--------|------------|----------------------------------------------|--|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value |  |
| 15:0      | RESULT | RO         | ADC conversion result6 register              |  |

# 22.13.20 ADC\_RESULT7 conversion result 7 register

Address offset: 0x3C Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                         |  |
|-----------|--------|------------|----------------------------------------------|--|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value |  |
| 15:0      | RESULT | RO         | ADC conversion result 7 register             |  |

# 22.13.21 ADC\_RESULTACC conversion result accumulated value register

Address offset: 0x40 Reset value: 0x0000 0000

| Bit field | Name   | Permission Function description |                                                  |
|-----------|--------|---------------------------------|--------------------------------------------------|
| 31:24     | RFU    | -                               | Reserved bits, please keep the default value     |
| 23:0      | RESULT | RO                              | ADC conversion result accumulated value register |

# 23 Analog voltage comparator (VC)

#### 23.1 Overview

CW32W031 integrates two analog voltage comparators (VC), which are used to compare two analog input voltages, and output the comparison results from the pins. The positive terminal input of the voltage comparator supports up to 8 external analog inputs, and the negative terminal supports not only 8 external analog inputs, but also internal voltage reference, internal resistance voltage divider, internal temperature sensor and other voltage references. The comparison result output has filtering function, hysteresis window function, and polarity selection. Support compare interrupt, which can be used to wake up MCU in low power mode.

### 23.2 Main features

- Dual-channel analog voltage comparators VC1, VC2
- Internal 64-step resistor divider
- Up to 8 external analog signal inputs
- 4 on-chip analog input signals
  - Built-in resistor divider output voltage
  - Built-in temperature sensor output voltage
  - Built-in 1.2V reference voltage
  - ADC reference voltage
- Selectable output polarity
- Supports hysteresis window compare function
- Programmable filters and filter time
- 3 interrupt trigger modes, which can be used in combination
  - High level trigger
  - Rising edge trigger
  - Falling edge trigger
- Supports running in low power mode, interrupt wake-up MCU

# 23.3 Functional description

### 23.3.1 Functional block diagram

The functional block diagram of the analog voltage comparator (VC) is shown in the following figure:

VC1\_CR0.INP VC1\_CH7 VC1\_INP VC1\_CH0 VC1\_CR1[7:5] VC1\_CR0.INN VC1\_CR0.IE VC1\_CR0.EN VC1\_CR0.POL VC1\_CR0.HYS VC1\_CH0 -VC1\_CR0.WINDOW Trigger condition VC1 interrupt selection VC1\_CH7 -VC1\_OUTA VC1\_INN VC1\_OUTP Temperature Sensor VC1\_OUTW 1.2V reference Digital ➤ VC1\_SR.FLTV voltage filtering ADC reference voltage -⊠ VC1\_OUT VC1\_CR1.FLTTIME VC1\_CR1.FLTCLK ADC reference voltage Resistor VCx\_DIV.DIV divider **VDDA** VCx\_DIV.VIN VC2 CR1.FLTCLK VC2\_CR1.FLTTIME -⊠ VC2\_OUT ADC reference voltage VC2\_OUTW Digital 1.2V reference ➤ VC2\_SR.FLTV VC2\_OUTP filtering VC2\_INN VC2\_OUTA Temperature Sensor  $\square$ VC2\_CH7 Trigger condition VC2\_CR0.WINDOW VC2 interrupt VC2\_CR0.HYS VC2\_CH0 VC2\_CR0.POL VC2\_CR0.EN VC2\_CR0.IE VC2\_CR0.INN VC2\_CR1[7:5] VC2\_CH0 VC2\_INP VC2\_CH7 VC2\_CR0.INP

Figure 23-1 VC functional block diagram

The input selection of the positive and negative terminals of VC1 and VC2 is selected by the INP and INN bit fields of the control register VCx\_CR0, as shown in the following table:



Table 23-1 VC positive and negative input signal configuration

| VCx_CR0.INP | VCx positive terminal input signal | VCx_CR0.INN | VCx negative terminal input signal                                                    |
|-------------|------------------------------------|-------------|---------------------------------------------------------------------------------------|
| 0000        | VCx_CH0                            | 0000        | VCx_CH0                                                                               |
| 0001        | VCx_CH1                            | 0001        | VCx_CH1                                                                               |
| 0010        | VCx_CH2                            | 0010        | VCx_CH2                                                                               |
| 0011        | VCx_CH3                            | 0011        | VCx_CH3                                                                               |
| 0100        | VCx_CH4                            | 0100        | VCx_CH4                                                                               |
| 0101        | VCx_CH5                            | 0101        | VCx_CH5                                                                               |
| 0110        | VCx_CH6                            | 0110        | VCx_CH6                                                                               |
| 0111        | VCx_CH7                            | 0111        | VCx_CH7                                                                               |
| -           | -                                  | 1000        | Built-in resistor divider output voltage                                              |
| -           | -                                  | 1001        | Reference voltage configured by ADC module Caution: ADC_CR0.EN should be enabled      |
| -           | -                                  | 1010        | Built-in 1.2V reference voltage                                                       |
| -           | -                                  | 1011        | Built-in temperature sensor output voltage<br>Caution: ADC_CR0.TSEN should be enabled |

The built-in resistor divider configuration is controlled by three bit fields in the VCx\_DIV register<sup>1</sup>:

- EN bit field, enable resistor divider
- VIN bit field, select the input voltage of the voltage divider
  - VIN is 0, select VDDA.
  - VIN is 1, select the reference voltage configured by the ADC module (Caution that the ADC must be enabled first).
- DIV bit field, voltage divider proportional coefficient, valid range is 0~63, select the output voltage of the voltage divider, the calculation formula is as follows:

Voltage divider output voltage = input voltage  $\times$  (1 + DIV) / 64

#### Caution 1:

VC1\_DIV and VC2\_DIV point to the same entity register, and VC1 and VC2 share the resistor divider circuit.

When selecting the built-in 1.2V reference voltage or the ADC module reference voltage as the negative input of the comparator, it is necessary to enable the BGR module inside the chip. The startup time of the internal BGR is about  $20\mu s$ , the VC voltage comparator needs to wait for the internal BGR to stabilize before it can work normally.

### 23.3.2 I/O pins

The analog voltage comparator supports 8 external analog signal inputs, and the user must configure the corresponding GPIO port as an analog function (GPIOx\_ANALOG.PINy = 1).

The analog voltage comparator supports outputting the comparison result from the pin. The user must configure the corresponding GPIO port as a digital output and select the function multiplexing.

The I/O pins supported by VC1 and VC2 are shown in the following table:

Table 23-2 VC I/O pins configuration

| VC1 I/O | GPIO | Configuration          | VC2 I/O | GPIO | Configuration          |
|---------|------|------------------------|---------|------|------------------------|
| VC1_CH0 | PA00 | Analog                 | VC2_CH0 | PA05 | Analog                 |
| VC1_CH1 | PA01 | Analog                 | VC2_CH1 | PA06 | Analog                 |
| VC1_CH2 | PA02 | Analog                 | VC2_CH2 | PA07 | Analog                 |
| VC1_CH3 | PA03 | Analog                 | VC2_CH3 | PB00 | Analog                 |
| VC1_CH4 | PA04 | Analog                 | VC2_CH4 | PB01 | Analog                 |
| VC1_CH5 | PA05 | Analog                 | VC2_CH5 | PB02 | Analog                 |
| VC1_CH6 | PA06 | Analog                 | VC2_CH6 | PB10 | Analog                 |
| VC1_CH7 | PA07 | Analog                 | VC2_CH7 | PB11 | Analog                 |
|         | PA06 | Digital output (AFR=3) |         | PA07 | Digital output (AFR=3) |
| VC1_OUT | PA00 | Digital output (AFR=4) | VC2_OUT | PA02 | Digital output (AFR=4) |
|         | PA11 | Digital output (AFR=4) |         | PA12 | Digital output (AFR=4) |

### 23.3.3 Latency/Response Time

Set the EN bit field of the control register VCx\_CR0 to 1 to enable the VC module.

The time from when VC is enabled or the input voltage at the positive and negative ends of VC changes to the time when the voltage comparator outputs the correct comparison result is defined as the delay/response time of the comparator. The delay/response time is configured by the RESP bit field of the control register VCx\_CR0. The response time value is adjustable from 200ns to  $20\mu s$  in four gears, and the shorter the response time, the greater the power consumption of the VC module.

#### 23.3.4 Polarity selection

The polarity of the output signals of the voltage comparators VC1 and VC2 is set by the POL bit field of the control register VCx\_CR0:

- POL is 1, the polarity of VCx\_OUTP signal is opposite to that of VCx\_OUTA signal, that is, when the positive terminal is greater than the negative terminal, VCx outputs a low level
- POL is 0, and the VCx\_OUTP signal has the same polarity as the VCx\_OUTA signal, that is, when the positive terminal is greater than the negative terminal, VCx outputs a high level

### 23.3.5 Digital filter

The built-in digital filter of the voltage comparator is used to digitally filter the output signal of the voltage comparator. It is controlled by the FLTEN bit field of the control register VCx\_CR1. FLTEN is 1 to enable digital filter, and FLTEN is 0 to disable digital filter. Users can use the filtering function to filter system noise, such as high current noise when the motor is stopped, to avoid system malfunction caused by the noise output of the comparator.

The clock for the digital filter is selected by the FLTCLK bit field in the control register VCx\_CR1:

- FLTCLK is 1, use PCLK as filter clock
- FLTCLK is 0, the built-in RC oscillator clock is used as the filter clock, and its frequency is about 150KHz

The filter width of the digital filter is selected by the FLTTIME bit field of the control register VCx\_CR1, and the signal whose width is less than a certain clock cycle is filtered out. There are 8 filter widths to choose from.

The digitally filtered output level of the voltage comparator can be read out through the FLTV bit field of the status register VCx\_SR.

When the user sets the VCx\_OUT pin as a digital output and selects the multiplexing function of the VC comparison output, the VCx\_OUT pin will output the digitally filtered output level of the voltage comparator.

The filter response waveform of VC is shown in the following figure:

Comparator output waveform

Digital filter circuit output waveform

Figure 23-2 VC filter response time

The output of the voltage comparator can be used as the BK brake input or OCREF\_CLR input of the advanced timer (ATIM), which is controlled by the ATIMBK and ATIMCLR bit fields of the control register VCx\_CR1 respectively. For the detailed introduction of BK and OCREF\_CLR, please refer to chapter *15 Advanced-control timer (ATIM)*. This function is usually used in motor protection applications, please refer to the relevant application Cautions for details.



#### 23.3.6 Hysteresis function

The analog voltage comparator supports the hysteresis function. After the hysteresis function is used, the output result of the comparator will not be reversed immediately with the change of the input signal, but will reverse only after the offset value of the two input signals is higher or lower than the hysteresis threshold voltage.

The waveform diagram of VC hysteresis function is shown in the following figure:

Negative terminal voltage + hysteresis

Negative terminal voltage - hysteresis

Positive terminal voltage - Hysteresis comparator output waveform

Figure 23-3 VC hysteresis function

The hysteresis function can effectively enhance the anti-interference ability of the chip, and avoid unnecessary frequent flipping of the output end of the comparator due to the small amplitude jitter of the input signal.

The hysteresis threshold voltage is determined by the HYS bit field of the control register VCx\_CR0, as shown in the following table:

| VCx_CR0.HYS | Hysteresis window configuration |
|-------------|---------------------------------|
| 00          | No hysteresis                   |
| 01          | Hysteresis window about 10mV    |
| 10          | Hysteresis window about 20mV    |
| 11          | Hysteresis window about 30mV    |

Table 23-3 VC hysteresis threshold voltage

#### 23.3.7 Window compare function

The analog voltage comparator supports the window compare function, which can output the comparison results of VC1 and VC2 after XOR operation, which is enabled by the WINDOW bit field of the control register VCx\_CR0.

When WINDOW is 1, the VCx\_OUTW signal is the XOR value of the VC1\_OUTP signal and the VC2\_OUTP signal; When WINDOW is 0, the VCx\_OUTW signal is at the same level as the VCx\_OUTP signal.



#### 23.3.8 BLANK window function

While keeping the VCx module working, if you want to temporarily stop the voltage comparison function, or in some application systems (such as motor control), the short-term reasonable fluctuation of the monitored signal may cause unnecessary reverse of output levels of voltage comparator, the voltage comparator of this chip has added the BLANK window function, that is, when the specified external trigger condition starts the BLANK window, no voltage comparison is performed within the set BLANK window, and the output level of the voltage comparator remains current. level status. After the BLANK window period, the voltage comparator resumes normal operation.

The BLANK window duration is configured by the BLANKFLT bit field of the control register VCx\_CR1. The window duration is

$$(2^{(BLANKFLT+2)} \sim 2^{(BLANKFLT+2)} + 2)$$
 PCLK cycles

As shown in the following table:

Table 23-4 BLANK window duration configuration

| VCx_CR1.BLANKFLT | The number of PCLK clocks in the BLANK window |
|------------------|-----------------------------------------------|
| 000              | 4 ~ 6                                         |
| 001              | 8 ~ 10                                        |
| 010              | 16 ~ 18                                       |
| 011              | 32 ~ 34                                       |
| 100              | 64 ~ 66                                       |
| 101              | 128 ~ 130                                     |
| 110              | 256 ~ 258                                     |
| 111              | 512 ~ 514                                     |

The trigger start condition of the BLANK window is configured by the BLANKCH1B, BLANKCH2B, and BLANKCH3B bit fields of the control register VCx\_CR1, and the BLANK window is triggered by the rising edge of CH1B, CH2B, and CH3B of ATIM respectively.

### 23.4 VC interrupts

The voltage comparator of CW32W031 supports working in low power consumption mode, and the comparison interrupt can wake up the chip from low power consumption mode.

Set the IE bit field of the control register VCx\_CR0 to 1 to enable the VCx interrupt. When an interrupt occurs, the interrupt flag bit INTF of the status register VCx\_SR will be set to 1 by hardware. The user can write 0 to the INTF bit to clear the interrupt flag.

Set the HIGHIE, RISEIE, FALLIE bit fields of the control register VCx\_CR1 to select different interrupt triggering methods:

- HIGHIE is 1, VCx\_OUT output signal high level triggers interrupt
- RISEIE is 1, the rising edge of VCx\_OUT output signal triggers interrupt
- FALLIE is 1, the falling edge of VCx\_OUT output signal triggers interrupt

# 23.5 Programming examples

In this example, the digital filtering function is used, and the compare interrupt is configured as follows:

- Step 1: Configure VCx\_DIV.EN to 1, enable the voltage divider;
- Step 2: Configure VCx\_DIV.DIV and set the voltage division coefficient;
- Step 3: Configure VCx\_CR0.INP and select the voltage source to be monitored at the positive terminal;
- Step 4: Configure VCx\_CR0.INN and select the voltage source to be monitored at the negative terminal;
- Step 5: Configure VCx\_CR1.FLTTIME and select the filter time;
- Step 6: Configure VCx\_CR1.FLTCLK, select filter clock;
- **Step 7:** Configure VCx\_CR1.FLTEN to 1 to enable VCx filter;
- Step 8: Set the HIGHIE, RISEIE, and FALLIE of the VCx\_CR1 register to 1, and select the interrupt trigger mode;
- Step 9: Set VCx CR0.IE to 1 to enable VCx interrupt;
- Step 10: Set VCx\_CR0.EN to 1 to enable VCx;
- Step 11: Wait for the VCx SR.READY flag to become 1;
- Step 12: In the initialization routine of the VC module and the interrupt service routine of the VC module, write 0 to the INTF bit of the VCx\_SR register, clear the interrupt flag, and enable the generation of the VCx interrupt.

# 23.6 List of registers

VC1 base address: VC1\_BASE = 0x4001 2A00 VC2 base address: VC2\_BASE = 0x4001 2A10

Table 23-5 List of VC registers

| Register name | Register address | Register description                           |
|---------------|------------------|------------------------------------------------|
| VCx_DIV       | VCx_BASE + 0x00  | Resistor divider control register <sup>1</sup> |
| VCx_CR0       | VCx_BASE + 0x04  | Control register 0                             |
| VCx_CR1       | VCx_BASE + 0x08  | Control register 1                             |
| VCx_SR        | VCx_BASE + 0x0C  | Status register                                |

### Caution 1:

VC1\_DIV and VC2\_DIV point to the same entity register, and VC1 and VC2 share the resistor divider circuit.



# 23.7 Register descriptions

See section 1 Documentation conventions for abbreviations used in register descriptions.

# 23.7.1 VCx\_DIV resistor divider control register

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                                       |
|-----------|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8      | RFU  | -          | Reserved bits, please keep the default value                                                                                               |
| 7         | VIN  | RW         | Resistor divider circuit input voltage setting 0: VDDA 1: The reference voltage configured by the ADC module (the ADC needs to be enabled) |
| 6         | EN   | RW         | Resistor divider circuit enable control 0: Disabled 1: Enabled                                                                             |
| 5:0       | DIV  | RW         | Resistor divider circuit output voltage configuration Output voltage = input voltage × (1 + DIV) / 64                                      |

#### Caution:

VC1\_DIV and VC2\_DIV point to the same entity register, and VC1 and VC2 share the resistor divider circuit.



# 23.7.2 VCx\_CR0 control register 0

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|--------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU    | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:12     | INN    | RW         | VCx negative terminal input signal configuration 0000: VCx_CH0 0001: VCx_CH1 0010: VCx_CH2 0011: VCx_CH3 0100: VCx_CH4 0101: VCx_CH5 0110: VCx_CH6 0111: VCx_CH7 1000: Built-in voltage divider output voltage 1001: The reference voltage configured by the ADC module (Caution: ADC_CR0.EN needs to be enabled) 1010: Built-in 1.2V reference voltage 1011: Built-in temperature sensor output voltage (Caution: ADC_CR0.TSEN needs to be enabled) Caution: To configure the ADC_CR0 register, you need to enable the ADC peripheral clock first |
| 11:8      | INP    | RW         | VCx positive terminal input signal configuration 0000: VCx_CH0 0001: VCx_CH1 0010: VCx_CH2 0011: VCx_CH3 0100: VCx_CH4 0101: VCx_CH5 0110: VCx_CH6 0111: VCx_CH7                                                                                                                                                                                                                                                                                                                                                                                   |
| 7         | WINDOW | RW         | Window compare function configuration 0: Window function disabled, VCx_OUTW signal equals VCx_OUTP signal 1: Window function enabled, VCx_OUTW signal equals to the XOR of VC1_OUTP and VC2_OUTP                                                                                                                                                                                                                                                                                                                                                   |
| 6         | POL    | RW         | VCx output signal polarity settings 0: When the positive terminal is greater than the negative terminal, VCx outputs a high level 1: When the positive terminal is greater than the negative terminal, VCx outputs a low level                                                                                                                                                                                                                                                                                                                     |
| 5         | IE     | RW         | Interrupt enable configuration 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Bit field | Name | Permission | Function description                                                                                                                                                         |
|-----------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:3       | HYS  | RW         | VCx hysteresis window configuration 00: No hysteresis 01: Hysteresis window about 10mV 10: Hysteresis window about 20mV 11: Hysteresis window about 30mV                     |
| 2:1       | RESP | RW         | VCx response speed configuration 00: Ultra-low speed 01:Low speed 10: Medium speed 11: High speed Caution: The faster the response speed, the greater the power consumption. |
| 0         | EN   | RW         | VCx enable control 0: Disabled 1: Enabled Caution: After enabling VCx, wait for the VCx_SR.READY flag bit to become 1.                                                       |

# 23.7.3 VCx\_CR1 control register 1

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name      | Permission | Function description                                                                                                                                                                                                                                                                               |
|-----------|-----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16     | RFU       | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                       |
| 15:13     | BLANKFLT  | RW         | BLANK window duration configuration: (2 <sup>(BLANKFLT+2)</sup> ~ 2 <sup>(BLANKFLT+2)</sup> +2) PCLK cycles Caution: Any rising edge of CH1B, CH2B, and CH3B of ATIM will trigger the start of the BLANK window. During the duration of the BLANK window, no voltage comparison will be performed. |
| 12        | BLANKCH3B | RW         | ATIM's CH3B rising edge triggers VCx to start BLANK window configuration 0: Disabled 1: Enabled                                                                                                                                                                                                    |
| 11        | BLANKCH2B | RW         | ATIM's CH2B rising edge triggers VCx to start BLANK window configuration 0: Disabled 1: Enabled                                                                                                                                                                                                    |
| 10        | BLANKCH1B | RW         | ATIM's CH1B rising edge triggers VCx to start BLANK window configuration 0: Disabled 1: Enabled                                                                                                                                                                                                    |
| 9         | ATIMBK    | RW         | ATIM's BK brake signal connectivity configuration 0: No function 1: VCx output connected to BK brake signal of ATIM                                                                                                                                                                                |
| 8         | ATIMCLR   | RW         | ATIM's OCREF_CLR signal connectivity configuration 0: No function 1: VCx output connected to OCREF_CLR signal of ATIM                                                                                                                                                                              |
| 7         | HIGHIE    | RW         | VCx output signal high level trigger interrupt enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                      |
| 6         | RISEIE    | RW         | VCx output signal rising edge trigger interrupt enabled 0: disable 1: Enabled                                                                                                                                                                                                                      |
| 5         | FALLIE    | RW         | VCx output signal falling edge trigger interrupt enabled 0: Disabled 1: Enabled                                                                                                                                                                                                                    |
| 4         | FLTCLK    | RW         | Digital filter module filter clock settings<br>0: Built-in RC oscillator clock, its frequency is about 150KHz<br>1: PCLK                                                                                                                                                                           |

| Bit field | Name    | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------|---------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1       | FLTTIME | RW         | Digital filter module filter time configuration 000: Filter out signals with width less than 1 clock cycle 001: Filter out signals with width less than 3 clock cycle 010: Filter out signals with width less than 7 clock cycles 011: Filter out signals with width less than 15 clock cycles 100: Filter out signals with width less than 63 clock cycles 101: Filter out signals with width less than 255 clock cycles 110: Filter out signals with width less than 1023 clock cycles 111: Filter out signals with width less than 4095 clock cycles |
| 0         | FLTEN   | RW         | Digital filter module enable configuration 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# 23.7.4 VCx\_SR status register

Address offset: 0x0C Reset value: 0x0000 0000

| Bit field | Name  | Permission | Function description                                                                                                                               |
|-----------|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3      | RFU   | -          | Reserved bits, please keep the default value                                                                                                       |
| 2         | READY | RO         | VCx status flag, by reading this bit to determine whether VCx has been stable 0: Not yet stable, cannot be used 1: Already stable and ready to use |
| 1         | FLTV  | RO         | Level value of digital filter output  0: Digital filter output low level  1: Digital filter output high level                                      |
| 0         | INTF  | RW0        | Interrupt flag R0: No VC interrupt occurred R1: VC interrupt has occurred W0: VC interrupt flag cleared W1: No function                            |

# 24 Low voltage detector (LVD)

### 24.1 Overview

Low voltage detector (LVD) is used to monitor VDDA power supply voltage or external pin input voltage. When the comparison result between the monitored voltage and the LVD threshold meets the trigger condition, an LVD interrupt or reset signal will be generated, which is usually used to handle some urgent tasks.

The interrupt and reset flags generated by the LVD can only be cleared by software; only after the interrupt or reset flag is cleared and the trigger condition is reached again, the LVD can generate an interrupt or reset signal again.

### 24.2 Main features

- 4-channel monitoring voltage source: VDDA power supply voltage, PA00, PB00, PB11 pin input
- 16-step threshold voltage, range 1.8V ~ 3.3V
- 3 trigger conditions, which can be used in combination
  - Level triggered: voltage below threshold
  - Falling edge trigger: the falling edge when the voltage falls below the threshold
  - Falling edge trigger: the falling edge when the voltage falls below the threshold
- Can trigger to generate interrupt or reset signal, both cannot be generated at the same time
- 8th order filter configurable
- Hysteresis function supported
- Supports running in low power mode, interrupt wake-up MCU

# 24.3 Functional description

### 24.3.1 Functional block diagram

The functional block diagram of the Low voltage detector (LVD) is shown in the following figure:



Figure 24-1 LVD functional block diagram

The LVD can monitor the VDDA power supply voltage, as well as the external pin input voltage (PA00, PB00, PB11), which is selected by the SOURCE bit field of the control register LVD\_CR0. When using external analog signal input, the user must configure the corresponding GPIO port as analog function (GPIOx\_ANALOG.PINy = 1).

The LVD output result can be output from the PA01 or PA08 pin, the user must configure the corresponding GPIO port as a digital output, and select function multiplexing at the same time.

### 24.3.2 Hysteresis function

The built-in voltage comparator of the LVD has a hysteresis function, which can avoid frequent flipping of the output result of the voltage comparator when the monitored voltage of the LVD is near the threshold voltage, and enhance the anti-interference ability of the system.

The comparator output signal toggles only when the monitored voltage is 20mV above or below the threshold voltage. The specific waveform is shown in the following figure:



Figure 24-2 LVD hysteretic response

The threshold voltage of LVD is determined by the VTH bit value of the control register LVD\_CR0, and the effective value is  $0 \sim 15$ , as shown in the following table:

Threshold voltage Threshold voltage LVD\_CR0.VTH LVD\_CR0.VTH (unit: V) (unit: V) 2.6 0000 1.8 1000 0001 1.9 1001 2.7 0010 2.0 1010 2.8 0011 2.1 1011 2.9 0100 2.2 1100 3.0 0101 2.3 1101 3.1 0110 3.2 2.4 1110 0111 2.5 1111 3.3

Table 24-1 LVD threshold voltage

### 24.3.3 Digital filter

In order to enhance the robustness of the system, the LVD supports the digital filtering function, which can digitally filter the output result signal of the LVD voltage comparison, and the signal smaller than the filtering width is filtered out without triggering an interrupt or reset. The specific waveform is shown in the following figure:

Hysteresis comparator output waveform

Digital filter circuit output waveform

Figure 24-3 LVD filter output

Set the FLTEN bit field of the control register LVD\_CR1 to 1 to enable the digital filter module;

The FLTCLK bit field of the control register LVD\_CR1 is used to select the clock for digital filter:

- FLTCLK bit is 1, select HSIOSC as filter clock
- FLTCLK bit is 0, and the built-in RC oscillator clock is selected as the filter clock, and its frequency is about 150KHz

The FLTTIME bit field of the control register LVD\_CR1 is used to select the number of clocks for digital filter, as shown in the following table:

| LVD_CR1.FLTTIME | Number of filter clocks |
|-----------------|-------------------------|
| 000             | 1                       |
| 001             | 3                       |
| 010             | 7                       |
| 011             | 15                      |
| 100             | 63                      |
| 101             | 255                     |
| 110             | 1023                    |
| 111             | 4095                    |

Table 24-2 Number of LVD digital filter clocks

From the FLTV bit field of the LVD status register LVD\_SR, the signal level after LVD digital filter can be read out; When the function of GPIO is multiplexed as LVD\_OUT, the digitally filtered signal can be output from GPIO to facilitate observation and measurement.

### 24.4 LVD interrupts

LVD supports working in low power mode, and interrupt output can wake up the chip from low power mode.

When the comparison result of the monitored voltage and the LVD threshold meets the trigger condition, an interrupt or reset signal can be generated. Whether to generate an interrupt or a reset signal is controlled by the ACTION bit field of the control register LVD\_CR0:

- ACTION is 1, LVD triggers to generate reset
- ACTION is 0, LVD triggers an interrupt

Set the IE bit field of the control register LVD\_CR0 to 1 to enable the LVD interrupt. When the trigger condition is met, an LVD interrupt will be generated. The interrupt flag bit LVD\_SR.INTF will be set to 1 by hardware. The user can write 0 to the INTF bit to clear the interrupt flag.

Set the LEVEL, FALL, and RISE bit fields of the control register LVD\_CR1 to select different interrupt or reset trigger methods. The three can be used in combination:

- LEVEL is 1, when the monitored voltage is lower than the threshold, an interrupt is triggered or a reset is generated
- FALL is 1, the falling edge of the monitored voltage falling below the threshold triggers an interrupt or generates a reset
- RISE is 1, the rising edge of the monitored voltage rises above the threshold to trigger an interrupt or generate a reset

### 24.5 Programming examples

### 24.5.1 Brown-out reset programming example

In this example, the MCU is reset when the monitored voltage falls below the threshold voltage, using digital filtering.

The configuration method is as follows:

- Step 1: Configure LVD\_CR0.SOURCE and select the voltage source to be monitored;
- Step 2: Configure LVD\_CR0.VTH and set the threshold voltage;
- Step 3: Configure LVD\_CR1.FLTTIME and select LVD filter time;
- Step 4: Configure LVD\_CR1.FLTCLK and select the filter clock;
- Step 5: Configure LVD\_CR1.FLTEN to enable LVD filter;
- Step 6: Set LVD\_CR1.LEVEL to 1, and select to trigger LVD action when the monitored voltage is lower than the threshold;
- Step 7: Set LVD\_CR0.ACTION to 1, and select LVD trigger action as system reset;
- Step 8: Set LVD\_CR0.EN to 1 to enable LVD.

### 24.5.2 Interrupt programming example

In this example, an interrupt is generated when the monitored voltage is above or below a threshold voltage, using digital filtering.

The configuration method is as follows:

- Step 1: Configure LVD\_CR0.SOURCE and select the voltage source to be monitored;
- Step 2: Configure LVD\_CR0.VTH and select the threshold voltage;
- Step 3: Configure LVD\_CR1.FLTTIME and select LVD filter time;
- Step 4: Configure LVD\_CR1.FLTCLK and select the filter clock;
- Step 5: Configure LVD\_CR1.FLTEN to enable LVD filter;
- Step 6: Set both LVD CR1.RISE and FALL to 1, and select rising and falling edge triggers;
- Step 7: Set LVD\_CR0.ACTION to 0, and select LVD trigger action as interrupt;
- Step 8: Set LVD\_CR0.IE to 1 to enable LVD interrupt;
- Step 9: Enable the LVD interrupt in the NVIC interrupt vector table;
- Step 10: Set LVD\_CR0.EN to 1 to enable LVD;
- Step 11: In the LVD initialization routine and the LVD interrupt service routine, write 0 to the LVD\_SR.INTF bit to clear the interrupt flag and allow a new LVD interrupt to be generated.



# 24.6 List of registers

LVD base address: LVD\_BASE = 0x4001 2A80

Table 24-3 List of LVD registers

| Register name | Register address | Register description |
|---------------|------------------|----------------------|
| LVD_CR0       | LVD_BASE + 0x00  | Control register 0   |
| LVD_CR1       | LVD_BASE + 0x04  | Control register 1   |
| LVD_SR        | LVD_BASE + 0x08  | Status register      |

# 24.7 Register descriptions

See section  ${\it 1 \, Documentation \, conventions}$  for abbreviations used in register descriptions.

# 24.7.1 LVD\_CR0 control register 0

Address offset: 0x00 Reset value: 0x0000 0000

| Bit field | Name   | Permission | Function description                                                                                                                     |
|-----------|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10     | RFU    | -          | Reserved bits, please keep the default value                                                                                             |
| 9         | IE     | RW         | Interrupt enable control 0: LVD interrupt disabled 1: LVD interrupt enable                                                               |
| 8         | RFU    | -          | Reserved bits, please keep the default value                                                                                             |
| 7:4       | VTH    | RW         | Threshold voltage selection 0000: 1.8V                                                                                                   |
| 3:2       | SOURCE | RW         | Monitor source configuration 00: VDDA supply voltage 01: PA00 port input voltage 10: PB00 port input voltage 11: PB11 port input voltage |
| 1         | ACTION | RW         | Trigger action configuration 0: NVIC interrupts 1: System resets                                                                         |
| 0         | EN     | RW         | Enable control 0: LVD disabled 1: LVD enabled                                                                                            |

# 24.7.2 LVD\_CR1 control register 1

Address offset: 0x04 Reset value: 0x0000 0000

| Bit field | Name    | Permission | Function description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------|---------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8      | RFU     | -          | Reserved bits, please keep the default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7         | LEVEL   | RW         | Triggered when the monitored voltage falls below the threshold level (that is, the LVD output signal is triggered by a high level) 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                         |
| 6         | FALL    | RW         | Trigger on falling edge of monitored voltage falling below threshold (that is, the rising edge of the LVD output signal is triggered) 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                      |
| 5         | RISE    | RW         | Triggered on rising edge when the monitored voltage rises back above the threshold (that is, the falling edge of the LVD output signal is triggered)  0: Disabled  1: Enabled                                                                                                                                                                                                                                                                                                                                                                     |
| 4         | FLTCLK  | RW         | Digital filter module filter clock settings 0: Built-in RC oscillator clock, its frequency is about 150KHz 1: HSIOSC                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3:1       | FLTTIME | RW         | Digital filter module filter time configuration 000: Filter out signals with width less than 1 clock cycle 001: Filter out signals with width less than 3 clock cycle 010: Filter out signals with width less than 5 clock cycle 011: Filter out signals with width less than 15 clock cycle 100: Filter out signals with width less than 63 clock cycle 101: Filter out signals with width less than 255 clock cycle 110: Filter out signals with width less than 1023 clock cycle 111: Filter out signals with width less than 4095 clock cycle |
| 0         | FLTEN   | RW         | Digital filter module enable configuration 0: Disabled 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

# 24.7.3 LVD\_SR status register

Address offset: 0x08 Reset value: 0x0000 0000

| Bit field | Name | Permission | Function description                                                                                                          |
|-----------|------|------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:2      | RFU  | -          | Reserved bits, please keep the default value                                                                                  |
| 1         | FLTV | RO         | Level value of digital filter output  0: Digital filter output low level  1: Digital filter output high level                 |
| 0         | INTF | RW0        | Interrupt flags R0: LVD interrupt did not occur R1: LVD interrupt has occurred W0: LVD interrupt flag cleared W1: No function |

# 25 Radio Frequency Systems (ChirpIoT)

### 25.1 Overview

CW32W031 is embedded with low-power long-range ChirploT ™ RF subsystem, operating at 370~590MHz and 740~1180MHz, supporting half-duplex wireless communication, supporting low rate mode from 0.08~20.4kbps, supporting automatic identification of spreading factor and CAD function.

The ChirploT ™ RF system features high interference immunity, high sensitivity, low power consumption and ultra-long transmission range. With up to -140dBm sensitivity and 22dBm maximum output power, it yields industry-leading link budgets, making it the best choice for long-range transmission and applications where reliability is critical.

The RF subsystem is accessed by the M0+ core through the internal high-speed SPI interface, and a comprehensive SDK for the underlying protocol software layer is available to support rapid solution building and product development.

#### 25.2 Main features

- Low-power long-range wireless transceiver
  - ChirpIoT ™
  - 370~590 MHz and 740~1180MHz
- Programmable output power: -7dBm ~ 22dBm
- Reception sensitivity: -140dBm @ 62.5kHz
- Support bandwidth: 62.5kHz, 125kHz, 250kHz, 500kHz
- Support spreading factor(SF): 7~12, support spreading factor auto-identification
- Support coding rate: 4/5, 4/6, 4/7, 4/8
- Support for CAD function
- Support low speed mode: 0.08 ~ 20.4kbps
- Fully integrated frequency synthesizer

# 25.3 Functional description

### 25.3.1 Functional block diagram

The RF subsystem integrates RF transmitter, RF receiver, crystal oscillator, frequency generator, power management and ChirploT ™ modem functional modules, as shown in the following figure:

DIG RX IF RF RX LNA  $\leq$ PGA  $Mixer_IQ$ ADC Mixer LPF Q  $\leq$ PGA BPF Data Sync Buffer **PLL** VCO **XTAL** PFD CP LPF Singal Decoder Demod DIG M/N Digital/Counter PΑ Modulator/VCO Calibration DAC Tx/Rx SPI Data FIFO DIG TX Interface BIAS Singal **PMU** Whitening Data Encode Modulation BDG LDO POR

Figure 25-1 RF system functional block diagram

### 25.3.2 MAC Design

#### Transmitter mode

The MAC transmit mode includes single packet transmit and continuous transmit modes, which are selected by the TX\_CFG\_MODE bit field of MAC module register Page3. After setting the TX mode, the state machine enters the TX ready state, waits for the FIFO to be written full of data, and then enters the TX transmit state.

When the MAC enters TX transmit mode, the power control module turns on the LDO, PLL, PA and other analog module circuits one after another, and then sends the TX start signal to the Modem module to start sending data.

After the data is sent, the analog module circuits such as LDO, PLL, and PA are turned off in turn. Then send IRQ signal to the CPU, and after the CPU clears IRQ, the operating mode configuration register selects OSC output mode (STB3) to end the TX process once.

The state flow diagrams for single packet sending mode and continuous sending mode are shown in the following diagrams, respectively:



Figure 25-2 Single packet transmit mode



Figure 25-3 Continuous transmit mode

#### Receiver mode

The MAC receive modes include single packet receive, single packet receive with timeout, and continuous receive, and are selected via the RX\_CFG\_MODE bit field of MAC module register Page3.

After setting the RX mode, the state machine enters the RX receive state.

When the MAC enters the receive mode, the power control module turns on the LDO, PLL, PA and other analog module circuits one after another, and sends the RX start signal to the Modem module to start receiving data.

After the data is received, the analog module circuits such as LDO, PLL, and PA are turned off in turn. Then the IRQ signal is sent to the CPU, and after the CPU clears the IRQ, the The operating mode configuration register selects the OSC output mode (STB3) and ends the RX process once.

The state flow diagrams for single packet receive mode, single packet receive mode with timeout, and continuous receive mode are shown below, respectively:

RX idle

RX initialization

No

Select RX mode?

Yes

Wait for RX receive completion interrupt

No

Read data

Clear RX IRQ

Figure 25-4 Single packet receive mode







Figure 25-6 Continuous receive mode

Continuous receive mode differs from single packet receive mode and single packet receive mode with timeout in that after data reception is completed, an IRQ signal is sent to the CPU, and the CPU clears the IRQ to start the next data reception. To exit the continuous receive mode, the operating mode configuration register selects the OSC output mode (STB3), and then turns off the analog module circuits such as LDO, PLL, PA, etc. in turn to end the continuous receive mode process.

#### 25.3.3 Operating modes

The RF system supports seven operating modes: Deep sleep mode(DeepSleep), Sleep mode(Sleep), OSC operating mode (STB1), LDO operating mode (STB2), OSC output mode (STB3), TX mode, and RX mode, which are configured through the OPERATE\_MODE bit field of the 3V logic area register. The operating mode state machine of the RF system after power-up is shown in the following figure:



Figure 25-7 RF operating status

- Deep Sleep mode (DeepSleep)
  - In this mode, except for the 3V logic area registers that can be configured, the rest of the modules are not operable, keeping chip power consumption to a minimum.
- Sleep mode (Sleep)
  - This mode enables LDO, 3V logic region operation, and registers can be configured via SPI interface.
- OSC operating mode(STB1)
  - This mode turns on the OSC crystal, and the OSC starts to work to maintain the oscillation but does not output to other modules, so the power consumption is relatively small.
  - In STB1 mode, write 1 to the EN\_DCDC bit field of DCDC register Page3 to enable the DCDC function; after turning on the DCDC function, when the RF system needs to enter sleep or deep sleep mode, it needs to turn off the DCDC function manually in advance.
- LDO operating mode (STB2)
  - In this mode the LDO starts to operate and the low voltage area logic is enabled.
- OSC output mode (STB3)
  - In this mode the OSC clock is output to each module and the chip starts to work normally.



#### TX mode

This mode has all TX transmit-related modules turned on for encoding and sending of packet data. Note that DCDC mode is only recommended for RX mode, DCDC on in TX mode will affect safety regulations.

#### RX mode

This mode has all RX receive-related modules turned on, waiting for the packet data to be received and decoded.

#### 25.3.4 Channel Active Detection (CAD)

Channel Activity Detection (CAD) is a wake-on-radio technique. Compared with the traditional Signal Strength Indication (RSSI), CAD is superior in detecting signals that may be lower than the receiver noise floor. The detection process is shown in the following figure:



Figure 25-8 Channel activity detection (CAD)

After initializing the CAD function and entering RX mode, the RF system will detect the presence of a ChirpIoT ™ signal in the channel with the same bandwidth and spreading factor parameters as the currently configured one. If present GPIO11 will generate a continuous steady high level (GPIO11 must be configured in output mode) indicating that a ChirpIoT ™ signal is searched for, and this high level will not pull low until the signal disappears.



The CPU can detect the GPIO11 port level for a certain period of time to determine if a ChirploT ™ signal is present in the channel. If the ChirploT ™ signal is present, it continues to wait for the IRQ interrupt for data reception and then proceeds with data reception; if the ChirploT ™ signal is not present, it quickly exits the RX mode and waits for a command to enter another mode.

The CAD signal detection threshold can be configured through the DETECTION bit field of the Modem module register Page1, and a value greater than this indicates the presence of a ChirploT™ signal. Different detection thresholds affect the reception sensitivity of the chip and there may be CAD false triggers. The effect of detection thresholds on reception sensitivity and false trigger probability is shown in the table below (experimental data was tested in a shielded room environment). When the use is completed, the CAD function needs to be turned off.

Table 25-1 Detection threshold settings

| Detection threshold                       | False trigger probability       | Reception sensitivity |
|-------------------------------------------|---------------------------------|-----------------------|
| 0x0A Very high (several times per minute) |                                 | No effect             |
| 0x10                                      | Higher (once every few minutes) | Decrease by 1dB       |
| 0x15 Lower (once every few hours)         |                                 | Decrease by 3dB       |
| 0x20                                      | Very low (0 times in 24 hours)  | Decrease by 5dB       |

#### 25.3.5 Intelligent SF identification

In order to realize the lightweight gateway device, CW32W031 integrates intelligent SF identification hardware circuit, which can realize the intelligent identification of SF mode of ChirploT ™ in the actual channel when receiving at the same frequency, and configure the chip SF parameters to achieve the purpose of receiving different SF signal data. The specific implementation flow is shown in the following figure:



Figure 25-9 Intelligent SF identification

#### 25.3.6 DATA FIFO

The RF subsystem has a 256-byte FIFO to store TX module transmit data and RX module decode data.

The FIFO consists of single-port RAM, which can only store and read single packet data information. If there is already a packet of data in the FIFO, the packet should be read before writing, otherwise the previous packet of data in the FIFO will be overwritten.

The FIFO can be read and written by Modem and SPI in STB3 and later operating modes.

#### 25.3.7 RF GPIO

The RF system supports input and output control of multiple GPIOs, which can be controlled through GPIO configuration registers. Each GPIO port can be configured as internal pull-up/pull-down input, high resistance input, push-pull output and other modes as shown in the table below.

Table 25-2 GPIO Port Mode Configuration

| DIEN | OE | OUT | IN  | PUEN | PDEN | GPIO mode             |
|------|----|-----|-----|------|------|-----------------------|
| 1    | 0  | -   | 0/1 | 0    | 0    | High resistance input |
| 1    | 0  | -   | 0/1 | 1    | 0    | Pull-up input         |
| 1    | 0  | -   | 0/1 | 0    | 1    | Pull-down input       |
| 0    | 1  | 0/1 | 0   | 0    | 0    | Push-pull output      |

GPIO10 and GPIO11 are multiplexed to implement special functions when configured as output mode.

When GPIO10 is configured to output mode, GPIO10 acts as an enable control pin for the external PA, i.e., GPIO10 outputs high only when sending data in transmit mode, and low in other states.

When GPIO11 is configured to output mode, GPIO11 acts as a channel active detection (CAD) output pin, i.e., it outputs a continuous and stable high level when the ChirpIoT ™ signal is searched for, and a low level in other states.

#### 25.3.8 RF Communication Timing

The RF system has a built-in SPI interface and is internally connected so that the M0+ kernel can access the RF registers and FIFO through this communication interface.

The RF system SPI interface supports level mode 0 (CPOL=0, CPHA=0), and the communication process starts with the SPI\_CS level pulled low until the SPI\_CS level is pulled high to end the transmission process.

The data transfer consists of two parts, Address Byte and Data Byte, as shown in the table below.

Table 25-3 Data Transfer Format

| Data Format | Address Byte                                      | Data Byte                                                                     |
|-------------|---------------------------------------------------|-------------------------------------------------------------------------------|
| Description | 7bit address + read/write bit (1: write; 0: read) | Data bytes support single-byte transmission and continuous transmission modes |

#### Caution:

In continuous transfer mode, the address between Data Byte is self-increasing when reading and writing registers, and the address between Data Byte is not self-increasing when reading and writing FIFO, it is always 0x01.

The following diagram shows the timing of the read/write operation of the RF system, where A[i] (i=6, 5, ..., 0) represents the address bits, W/R is the read/write bits, and Dn[i] (i=7, 6, 5, ..., 0) represents the data bits of the nth data.

Figure 25-10 Read Operation Timing



Figure 25-11 Write Operation Timing





## 25.4 RF interrupts

RF system supports four interrupt sources, when the RF interrupt trigger event occurs, the interrupt flag bit will be set by hardware, and trigger the internal interrupt pin IRQ output high (IRQ default state is low).

The flag bits and interrupt flag clearing methods for each interrupt source of the RF system are shown in the following table:

Table 25-4 RF system interrupt control

| Interrupt event           | Interrupt flag bit | Flag clear method            |
|---------------------------|--------------------|------------------------------|
| FIFO send complete        | TX_DONE_IRQ        | Write 1 to TX_DONE_IRQ       |
| FIFO receive timeout      | RX_TIMEOUT_IRQ     | Write 1 to RX_TIMEOUT_IRQ    |
| Receive PAYLOAD CRC error | RX_PL_CRC_ERR_IRQ  | Write 1 to RX_PL_CRC_ERR_IRQ |
| FIFO receive complete     | RX_DONE_IRQ        | Write 1 to RX_DONE_IRQ       |

## 25.5 Register descriptions

The RF subsystem has a separate physical address space, and the M0+ kernel accesses the RF subsystem through the internal high-speed SPI interface. The RF registers are divided into 4 pages (Page0~Page3) with 128 register addresses per page (0x00~0x7F), and the register pages are selected through the PAGE\_SEL bit field of the RF system control register. System control registers and 3V logical area registers (address 0x00~0x04) can be operated in any of the register pages.

### 25.5.1 System control register

| Address | Bit<br>field | Name                            | Permission | Reset<br>value | Function description                                                                 |
|---------|--------------|---------------------------------|------------|----------------|--------------------------------------------------------------------------------------|
|         | 7            | SOFT_RST                        | RW         |                | Soft reset                                                                           |
|         | 6:2          | RFU                             | RW         |                | Reserved bits                                                                        |
| 0x00    | 1:0          | PAGE_SEL                        | RW         | 0x00           | Select register page 0: Select Page0 1: Select Page1 2: Select Page2 3: Select Page3 |
| 0x01    | 7:0          | FIFO_READ_WRITE_ACESS_<br>POINT | RW         | -              | FIFO read/write address                                                              |

# 25.5.2 3V Logic area register

| Address | Bit<br>field | Name             | Permission | Reset<br>value | Function description                                                                                                                                                                        |
|---------|--------------|------------------|------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 7:3          | RFU              | RW         |                | Reserved bits                                                                                                                                                                               |
| 0x02    | 2:0          | OPERATE_MODE     | RW         | 0x00           | Operating mode configuration 0: Deep sleep mode (DeepSleep) 1: Sleep mode (Sleep) 2: OSC operating mode (STB1) 3: LDO operating mode (STB2) 4: OSC output mode (STB3) 5: TX mode 6: RX mode |
|         | 7:6          | RFU              | RW         |                | Reserved bits                                                                                                                                                                               |
|         | 5            | LDO_LOW_SR       | RW         |                | Enable low-power on-chip capacitor LDO swing rate extension function 0: Disable 1: Enable                                                                                                   |
| 0x03    | 4            | LDO_DVDD_LP_SEL  | RW         | 0x0C           | Low power LDO mode selection 0: No off-chip capacitor mode 1: Off-chip capacitor mode                                                                                                       |
|         | 3:0          | LDO_DVDD_LP_VSEL | RW         |                | Low power LDO output voltage configuration (please do not modify the default configuration)                                                                                                 |
|         | 7            | RFU              | RW         |                | Reserved bits                                                                                                                                                                               |
|         | 6            | LDO_LOW_EN       | RW         |                | DVDD weak LDO enable control 0: Disable weak LDO 1: Enable weak LDO                                                                                                                         |
| 0x04    | 5            | LEVEL_SHIFT_EN   | RW         | 0x06           | 3.3V to 1.5V level conversion enable control 0: Disable level shift 1: Enable level shift                                                                                                   |
|         | 4            | POR_NRSTL        | RW         |                | 1.5V low voltage area logic reset 0: No reset 1: Reset                                                                                                                                      |
|         | 3:0          | RFU              | RW         |                | Reserved bits                                                                                                                                                                               |

## 25.5.3 DCDC register

### 25.5.3.1 Page3

| Address | Bit<br>field | Name    | Permission | Reset<br>value | Function description                               |
|---------|--------------|---------|------------|----------------|----------------------------------------------------|
|         | 7:1          | RFU     | RW         |                | Reserved bits                                      |
| 0x1E    | 0            | EN_DCDC | RW         | 0x6C           | DCDC enable control 0: Disable DCDC 1: Enable DCDC |

## 25.5.4 Low power consumption power control register

### 25.5.4.1 Page1

| Address | Bit<br>field | Name          | Permission | Reset<br>value | Function description                                                                                                          |
|---------|--------------|---------------|------------|----------------|-------------------------------------------------------------------------------------------------------------------------------|
|         | 7:4          | 2ND_RAMP_CTRL | RW         |                | Set the maximum value reached when PA_2ND_PWR[3:0] is UP                                                                      |
| 0x63    | 3            | RFU           | RW         | 0xF7           | Reserved bits                                                                                                                 |
|         | 2:0          | 1ST_RAMP_CTRL | RW         |                | Set the maximum value reached when PA_1ST_PWR[2:0] is UP                                                                      |
|         | 7:5          | RFU           | RW         |                | Reserved bits                                                                                                                 |
| 0x64    | 4            | 2ND_EN_CTRL   | RW         | 0x1F           | Set the maximum value reached when PA_2ND_EN is UP                                                                            |
|         | 3:0          | 2ND_VC_CTRL   | RW         |                | Set the maximum value reached when PA_2ND_VC[3:0] is UP                                                                       |
| 0x66    | 7            | RAMP_DN_TICK  | RW         | 0x00           | Set the clock period of the external PA when RAMP DOWN 0: 4µs 1: 2µs                                                          |
|         | 6:0          | RFU           | RW         |                | Reserved bits                                                                                                                 |
|         | 7            | PA_OSIDE_EN   | RW         |                | External PA enable control 0: External PA is not used 1: Use external PA and join RAMP ranks                                  |
| 0x67    | 6:0          | PA_OSIDE_TIME | RW         | 0x40           | Set the time from the end of<br>the on-chip RAMP UP to the<br>off-chip PA_EN pull-up<br>[6:0]×4µs = 0~508µs, default<br>256µs |



## 25.5.5 Modem module register

## 25.5.5.1 Page1

| Address | Bit<br>field | Name               | Permission | Reset<br>value | Function description                                                                                     |
|---------|--------------|--------------------|------------|----------------|----------------------------------------------------------------------------------------------------------|
|         | 7:5          | RFU                | RW         |                | Reserved bits                                                                                            |
| 0x0B    | 4            | RFU                | RW         | 0x98           | During initialization, please change the configuration to 1                                              |
|         | 3:0          | RFU                | RW         |                | Reserved bits                                                                                            |
| 0x0C    | 7:0          | PAYLOAD_LEN        | RW         | 0x0A           | Send payload length configuration, unit is byte                                                          |
|         | 7            | RFU                | RW         |                | Reserved bits                                                                                            |
|         | 6            | INVERTIQ_IN        | RW         |                | Input IQ signal swapping selection 0: Input IQ signal is not swapped 1: Input IQ signal is swapped       |
| 0x0E    | 5            | RFU                | RW         | 0x04           | Reserved bits                                                                                            |
|         | 4            | SIGNSWITCH_IN      | RW         |                | Input IQ signal sign selection 0: Input IQ signal is unsigned number 1: Input IQ signal is signed number |
|         | 3:0          | RFU                | RW         |                | Reserved bits                                                                                            |
| 0x0F    | 7:0          | DETECTION          | RW         | 0x04           | Detection threshold, greater<br>than this value indicates the<br>presence of a ChirploT ™ signal         |
|         | 7:4          | RFU                | RW         |                | Reserved bits                                                                                            |
| 0×1E    | 3            | DIGMODE_SEL        | RW         | 0x00           | High power mode enable control 0: Disable high power mode 1: Enable high power mode                      |
|         | 2:1          | IQ_SEL             | RW         |                | IQ signal output selection in RF test mode                                                               |
|         | 0            | RFU                | RW         |                | Reserved bits                                                                                            |
| 0x74    | 7:0          | SIG_POW_AVG[7:0]   | R          | -              | Signal-to-noise ratio, low 8 bits, output value is the signal-to-noise ratio                             |
| 0x75    | 7:0          | SIG_POW_AVG[15:8]  | R          | -              | Signal-to-noise ratio, next highest 8 bits                                                               |
| 0x76    | 7:0          | SIG_POW_AVG[23:16] | R          | -              | Signal-to-noise ratio, high 8 bits                                                                       |



Rev 1.0

| Address | Bit<br>field | Name                     | Permission | Reset<br>value | Function description                                                                                                                  |
|---------|--------------|--------------------------|------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0x77    | 7:0          | ORI_DEC_FREQ_BUFF[7:0]   | R          | -              | Frequency bias calculation value, low 8 bits Frequency bias calculation formula: Freq=ORI_DEC_FREQ_BUFF/(2 <sup>SF</sup> ) Unit is Hz |
| 0x78    | 7:0          | ORI_DEC_FREQ_BUFF[15:8]  | R          | -              | Frequency bias calculation value, next lower 8 bits                                                                                   |
| 0x79    | 7:0          | ORI_DEC_FREQ_BUFF[23:16] | R          | -              | Frequency bias calculation value, next highest 8 bits                                                                                 |
|         | 7:2          | RFU                      | R          |                | Reserved bits                                                                                                                         |
| 0x7A    | 1:0          | ORI_DEC_FREQ_BUFF[25:24] | R          | -              | Frequency bias calculation value, high 2 bits                                                                                         |
|         | 7:6          | RFU                      | R          |                | Reserved bits                                                                                                                         |
|         | 5            | DC_DONE                  | R          |                | DC compensation calculation completion flag                                                                                           |
| 0x7B    | 4            | PAYLOAD_CR_ERR           | R          | -              | Receive payload coding rate calculation error flag                                                                                    |
|         | 3            | CRC_MAC                  | R          |                | CRC function on or off flag                                                                                                           |
|         | 2:0          | CR                       | R          |                | The encoding rate of the received packets                                                                                             |
|         | 7:3          | RFU                      | R          |                | Reserved bits                                                                                                                         |
| 0x7C    | 2            | HEADER_CRC               | R          | -              | Receiver header CRC                                                                                                                   |
|         | 1:0          | RFU                      | R          |                | Reserved bits                                                                                                                         |
| 0x7D    | 7:0          | PAYLOAD_LEN              | R          | -              | Length of received data payload                                                                                                       |
| 0x7E    | 7:0          | RSSI_MIX_HOLD            | R          | -              | Current RSSI calculation value                                                                                                        |
| 0x7F    | 7:0          | RSSI_FIR_HOLD            | R          | -              | Current RSSI calculation value                                                                                                        |

## 25.5.5.2 Page2

| Address | Bit<br>field | Name               | Permission | Reset<br>value | Function description                                                                         |
|---------|--------------|--------------------|------------|----------------|----------------------------------------------------------------------------------------------|
| 0x6C    | 7:0          | RSSI_MIX_CHG       | R          | -              | Current RSSI calculation value, the output value is RSSI value                               |
| 0x6D    | 7:0          | RSSI_FIR_CHG       | R          | -              | Current RSSI calculation value                                                               |
| 0x6E    | 7:0          | GAIN_GRID          | R          | -              | AGC gain, the output value is the AGC gain value                                             |
| 0x6F    | 7:0          | AGC_SET[7:0]       | R          | -              | Set AGC control code, low 8 bits                                                             |
| 0x70    | 7:0          | AGC_SET[15:8]      | R          | -              | Set AGC control code, high 8 bits                                                            |
| 0x71    | 7:0          | NOI_POW_AVG[7:0]   | R          | -              | The average value of the noise power signal, low 8 bits, the output value is the noise power |
| 0x72    | 7:0          | NOI_POW_AVG[15:8]  | R          | -              | The average value of the noise power signal, next highest 8 bits                             |
| 0x73    | 7:0          | NOI_POW_AVG[23:16] | R          | -              | The average value of the noise power signal, high 8 bits                                     |
| 0x74    | 7:0          | DC_OFFSET_O_I      | R          |                | DC compensation results                                                                      |
| 0x75    | 7:0          | DC_OFFSET_O_Q      | R          | -              | DC compensation results                                                                      |

## 25.5.5.3 Page3

| Address | Bit<br>field | Name              | Permission | Reset<br>value | Function description                                                                                                                                                     |
|---------|--------------|-------------------|------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x09    | 7:0          | SYNC_FREQC[7:0]   | RW         | 0x40           | RF frequency configuration, low 8 bits                                                                                                                                   |
| 0x0A    | 7:0          | SYNC_FREQC[15:8]  | RW         | 0x0E           | RF frequency configuration, next lower 8 bits                                                                                                                            |
| 0x0B    | 7:0          | SYNC_FREQC[23:16] | RW         | 0xCF           | RF frequency configuration, next highest 8 bits                                                                                                                          |
|         | 7:6          | RFU               | RW         |                | Reserved bits                                                                                                                                                            |
| 0x0C    | 5:0          | SYNC_FREQC[29:24] | RW         | 0x19           | RF frequency configuration, high 6 bits                                                                                                                                  |
|         | 7:4          | BW                | RW         |                | Bandwidth configuration 6: 62.5 kHz 7: 125 kHz 8: 250 kHz 9: 500 kHz                                                                                                     |
| 0x0D    | 3:1          | CODING_RATE       | RW         | 0x98           | Coding rate configuration 1: 4/5 2: 4/6 3: 4/7 4: 4/8                                                                                                                    |
|         | 0            | RFU               | RW         |                | Reserved bits                                                                                                                                                            |
| 0x0E    | 7:4          | SPREADING_FACTOR  | RW         | 0x78           | Spreading factor configuration 7: 128 chips / symbol 8: 256 chips / symbol 9: 512 chips / symbol 10: 1024 chips / symbol 11: 2048 chips / symbol 12: 4096 chips / symbol |
|         | 3            | RX_PAYLOAD_CRC_ON | RW         |                | 0: CRC disable<br>1: CRC enable                                                                                                                                          |
|         | 2:0          | RFU               | RW         |                | Reserved bits                                                                                                                                                            |
| 0x0F    | 7:0          | SYNCWORD          | RW         | 0x12           | Sync word configuration Configuration range is 0x10~0xFF                                                                                                                 |
| 0x10    | 7:0          | IF[7:0]           | RW         | 0x40           | Medium frequency configuration, low 8 bits                                                                                                                               |
|         | 7:4          | RFU               | RW         |                | Reserved bits                                                                                                                                                            |
| 0x11    | 3:0          | IF[11:8]          | RW         | 0x00           | Medium frequency configuration, high 4 bits                                                                                                                              |

| Address | Bit<br>field | Name               | Permission | Reset<br>value                                                               | Function description                                                                                                                          |
|---------|--------------|--------------------|------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|         | 7:4          | RFU                | -          |                                                                              | Reserved bits                                                                                                                                 |
|         | 3            | 3 LOWDATARATE RW   |            | Low rate mode configuration 0: Disable low rate mode 1: Enable low rate mode |                                                                                                                                               |
| 0x12    | 2:1          | RFU                | -          | 0x00                                                                         | Reserved bits                                                                                                                                 |
| UXIZ    | 0            | SF_SYC_EN          | RW         | 0x00                                                                         | SF intelligent identification mode configuration  0: Disable SF intelligent identification mode  1: Enable SF intelligent identification mode |
| 0x13    | 7:0          | PREAMBLE_LEN[7:0]  | RW         | 0x08                                                                         | Preamble length, low 8 bits                                                                                                                   |
| 0x14    | 7:0          | PREAMBLE_LEN[15:8] | RW         | 0x00                                                                         | Preamble length, high 8 bits                                                                                                                  |

## 25.5.6 MAC module register

### 25.5.6.1 Page0

| Address | Bit<br>field | Name              | Permission | Reset<br>value | Function description                                                          |
|---------|--------------|-------------------|------------|----------------|-------------------------------------------------------------------------------|
|         | 7:4          | RFU               | RW         |                | Reserved bits                                                                 |
|         | 3            | RX_DONE_IRQ       | RW         |                | FIFO receive completion interrupt flag Write 1 to clear this interrupt flag   |
| 0x6C    | 2            | RX_PL_CRC_ERR_IRQ | RW         | 0x00           | Receive PAYLOAD CRC error interrupt flag Write 1 to clear this interrupt flag |
|         | 1            | RX_TIMEOUT_IRQ    | RW         |                | FIFO receive timeout interrupt flag Write 1 to clear this interrupt flag      |
|         | 0            | TX_DONE_IRQ       | RW         |                | FIFO send completion interrupt flag Write 1 to clear this interrupt flag      |

## 25.5.6.2 Page3

| Address | Bit<br>field | Name             | Permission | Reset<br>value | Function description                                                                                                                         |
|---------|--------------|------------------|------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
|         | 7:6          | RFU              | RW         |                | Reserved bits                                                                                                                                |
|         | 5            | ISO_TO_0         | RW         |                | Operating isolation setting 0: Operating voltage isolation 1: Voltage normal operation                                                       |
|         | 4:3          | RFU              | RW         |                | Reserved bits                                                                                                                                |
| 0x06    | 2            | TX_CFG_MODE      | RW         | 0x00           | Transmitter operating mode configuration 0: Single packet transmit mode 1: Continuous transmit mode                                          |
|         | 1:0          | RX_CFG_MODE      | RW         |                | Receiver operating mode configuration 00: Single packet receive mode 01: Single packet receive mode with timeout 10: Continuous receive mode |
| 0x07    | 7:0          | RX_TIMEOUT[7:0]  | RW         | 0x00           | Receive timeout setting, low 8 bits, unit ms                                                                                                 |
| 0x08    | 7:0          | RX_TIMEOUT[15:8] | RW         | 0x00           | Receive timeout setting, high<br>8 bits, unit ms                                                                                             |

# 25.5.7 Intelligent SF identification register

## 25.5.7.1 Page1

| Address | Bit<br>field | Name         | Permission | Reset<br>value | Function description                                                                                                   |
|---------|--------------|--------------|------------|----------------|------------------------------------------------------------------------------------------------------------------------|
|         | 7:6          | SFA_SCAN_SYM | RW         |                | SF10 scan time 0: 1.5 SF10 chirp symbols 1: 1.8 SF10 chirp symbols 2: 2.0 SF10 chirp symbols 3: 2.5 SF10 chirp symbols |
| 0x1C    | 5:4          | SF9_SCAN_SYM | RW         | 0,00           | SF9 scan time 0: 1.5 SF9 chirp symbols 1: 1.8 SF9 chirp symbols 2: 2.0 SF9 chirp symbols 3: 2.5 SF9 chirp symbols      |
| UXIC    | 3:2          | SF8_SCAN_SYM | RW         | 0x00           | SF8 scan time 0: 1.5 SF8 chirp symbols 1: 1.8 SF8 chirp symbols 2: 2.0 SF8 chirp symbols 3: 2.5 SF8 chirp symbols      |
|         | 1:0          | SF7_SCAN_SYM | RW         |                | SF7 scan time 0: 1.5 SF7 chirp symbols 1: 1.8 SF7 chirp symbols 2: 2.0 SF7 chirp symbols 3: 2.5 SF7 chirp symbols      |
|         | 7:4          | RFU          | RW         |                | Reserved bits                                                                                                          |
| 0x1D    | 3:2          | SFC_SCAN_SYM | RW         | 0x00           | SF12 scan time 0: 1.5 SF12 chirp symbols 1: 1.8 SF12 chirp symbols 2: 2.0 SF12 chirp symbols 3: 2.5 SF12 chirp symbols |
|         | 1:0          | SFB_SCAN_SYM | RW         |                | SF11 scan time 0: 1.5 SF11 chirp symbols 1: 1.8 SF11 chirp symbols 2: 2.0 SF11 chirp symbols 3: 2.5 SF11 chirp symbols |

| Address | Bit<br>field | Name     | Permission | Reset<br>value | Function description                                                                 |
|---------|--------------|----------|------------|----------------|--------------------------------------------------------------------------------------|
|         | 7:6          | RFU      | RW         |                | Reserved bits                                                                        |
|         | 5            | SFCCYCLE | RW         |                | 0: Disable intelligent SF12 identification 1: Enable intelligent SF12 identification |
|         | 4            | SFBCYCLE | RW         | 0x00           | 0: Disable intelligent SF11 identification 1: Enable intelligent SF11 identification |
| 0x2D    | 3            | SFACYCLE | RW         |                | 0: Disable intelligent SF10 identification 1: Enable intelligent SF10 identification |
|         | 2            | SF9CYCLE | RW         |                | 0: Disable intelligent SF9 identification 1: Enable intelligent SF9 identification   |
|         | 1            | SF8CYCLE | RW         |                | 0: Disable intelligent SF8 identification 1: Enable intelligent SF8 identification   |
|         | 0            | SF7CYCLE | RW         |                | 0: Disable intelligent SF7 identification 1: Enable intelligent SF7 identification   |

## 25.5.7.2 Page3

| Address | Bit<br>field | Name        | Permission | Reset<br>value | Function description                                                                                                                 |
|---------|--------------|-------------|------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------|
|         | 7:4          | RFU         | -          |                | Reserved bits                                                                                                                        |
|         | 3            | LOWDATARATE | RW         | 0x00           | Low rate mode configuration 0: Disable low rate mode 1: Enable low rate mode                                                         |
| 0x12    | 2:1          | RFU         | -          |                | Reserved bits                                                                                                                        |
| UX12    | 0            | SF_SYC_EN   | RW         |                | SF intelligent identification mode enable 0: Disable SF intelligent identification mode 1: Enable SF intelligent identification mode |

# 25.5.8 PLL module register

## 25.5.8.1 Page3

| Address | Bit<br>field | Name            | Permission | Reset<br>value                    | Function description                                           |
|---------|--------------|-----------------|------------|-----------------------------------|----------------------------------------------------------------|
|         | 7            | RFU             | RW         |                                   | Reserved bits                                                  |
| 0x15    | 6:0          | FB              | RW         | 0x21                              | Operating frequency configuration                              |
| 0x16    | 7:0          | FC[7:0] RW 0x04 |            | Operating frequency configuration |                                                                |
|         | 7:4          | RFU             | RW         |                                   | Reserved bits                                                  |
| 0x17    | 3:0          | FC[11:8]        | RW         | 0x01                              | Operating frequency configuration                              |
|         | 7:4          | RFU             | RW         |                                   | Reserved bits                                                  |
|         | 3            | MODE_SEL        | RW         |                                   | PLL Configuration 0: High frequency mode 1: Low frequency mode |
| 0x18    | 2            | LBS             | RW         | 0x0F                              | Operating frequency band configuration                         |
|         | 1            | LBS2            | RW         |                                   | Operating frequency band configuration                         |
|         | 0            | HI_LO_SET       | RW         |                                   | Operating frequency band configuration                         |
| 0x19    | 7:5          | RFU             | RW         | 0x08                              | Reserved bits                                                  |
| UXIS    | 4:0          | CAL_CODE        | RW         | UXUO                              | Calibration configuration                                      |



# 25.5.9 GPIO configuration register

### 25.5.9.1 Page0

| Address | Bit<br>field | Name          | Permission | Reset<br>value | Function description                                                                                                                 |
|---------|--------------|---------------|------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 0x5F    | 7:0          | GPIO_PDEN_LSB | RW         | 0x00           | GPIO pull-down enable control<br>Bit7~Bit0 correspond to<br>GPIO7~GPIO0 respectively<br>0: Disable pull-down<br>1: Enable pull-down  |
|         | 7:4          | RFU           | RW         |                | Reserved bits                                                                                                                        |
| 0x60    | 3:0          | GPIO_PDEN_MSB | RW         | 0x00           | GPIO pull-down enable control<br>Bit3~Bit0 correspond to<br>GPIO11~GPIO8 respectively<br>0: Disable pull-down<br>1: Enable pull-down |
| 0x61    | 7:0          | GPIO_PUEN_LSB | RW         | 0x00           | GPIO pull-up enable control Bit7~Bit0 correspond to GPIO7~GPIO0 respectively 0: Disable pull-up 1: Enable pull-up                    |
|         | 7:4          | RFU           | RW         |                | Reserved bits                                                                                                                        |
| 0x62    | 3:0          | GPIO_PUEN_MSB | RW         | 0x00           | GPIO pull-up enable control Bit3~Bit0 correspond to GPIO11~GPIO8 respectively 0: Disable pull-up 1: Enable pull-up                   |
| 0x63    | 7:0          | GPIO_DIEN_LSB | RW         | 0x00           | GPIO input enable control Bit7~Bit0 correspond to GPIO7~GPIO0 respectively 0: Disable input 1: Enable input                          |
|         | 7:4          | RFU           | RW         |                | Reserved bits                                                                                                                        |
| 0x64    | 3:0          | GPIO_DIEN_MSB | RW         | 0x00           | GPIO input enable control Bit3~Bit0 correspond to GPIO11~GPIO8 respectively 0: Disable input 1: enable input                         |
| 0x65    | 7:0          | GPIO_OE_LSB   | RW         | 0x00           | GPIO output enable control Bit7~Bit0 correspond to GPIO7~GPIO0 respectively 0: Disable output 1: Enable output                       |



| Address | Bit<br>field | Name         | Permission | Reset<br>value | Function description                                                                                                                                                                                                                                                                                   |  |
|---------|--------------|--------------|------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|         | 7:4          | RFU          | RW         |                | Reserved bits                                                                                                                                                                                                                                                                                          |  |
| 0x66    | 3:0          | GPIO_OE_MSB  | RW         | 0x00           | GPIO output enable control Bit3~Bit0 correspond to GPIO11~GPIO8 respectively 0: Disable output 1: Enable output                                                                                                                                                                                        |  |
| 0x67    | 7:0          | GPIO_OUT_LSB | RW         | 0x00           | GPIO output level control Bit7~Bit0 correspond to GPIO7~GPIO0 respectively 0: Output low level 1: Output high level                                                                                                                                                                                    |  |
|         | 7:2          | RFU          | RW         |                | Reserved bits                                                                                                                                                                                                                                                                                          |  |
| 0x68    | 1:0          | GPIO_OUT_MSB | RW         | 0x00           | GPIO output level control Bit1~Bit0 correspond to GPIO9~GPIO8 respectively 0: Output low level 1: Output high level Caution: GPIO11 and GPIO10 outputs are occupied by channel status indication signal and external PA enable control signal respectively, which are not controlled by this Bit field |  |
|         | 7:6          | RFU          | R          |                | Reserved bits                                                                                                                                                                                                                                                                                          |  |
| 0x74    | 5:0          | GPIO_IN_LSB  | R          | -              | GPIO input level status Bit5~Bit0 correspond to GPIO5~GPIO0 respectively 0: Input is low level 1: Input is high level                                                                                                                                                                                  |  |
|         | 7:6          | RFU          | R          |                | Reserved bits                                                                                                                                                                                                                                                                                          |  |
| 0x75    | 5:0          | GPIO_IN_MSB  | R          | -              | GPIO input level status Bit5~Bit0 correspond to GPIO11~GPIO6 respectively 0:Input is low level 1: Input is high level                                                                                                                                                                                  |  |

## 26 Debug interface (DBG)

#### 26.1 Overview

The core of CW32W031 is ARM® Cortex®-M0+, the core has built-in DAP hardware debug module, and supports SWD mode debugging. The hardware debug module can be suspended when fetching instructions (instruction breakpoints) or accessing data (data breakpoints), and the program stops running. query; and the core and peripherals can be restored, and program execution continues.

When using the debugging simulation tool to connect to the CW32W031 through the SWD interface, enter the debugging mode, and perform debugging operations through the DAP hardware debugging module in the chip core.

### 26.2 Serial wire debug port SWD

Use the SWD interface of the CW special debugger or the general debugging simulation tool to connect with the DAP debugging module inside the target chip, and carry out data exchange through the packet transmission protocol to realize the debugging operation. The SWD mode is a 2-wire serial communication, including a clock line SWCLK and a bidirectional data line SWDIO. As shown in the following figure:



Figure 26-1 SWD functional block diagram

The pin assignment of the SWD interface of the CW32W031 series is shown in the following table. The PA13/PA14 pin is the SWD function by default when the chip leaves the factory.

Table 26-1 SWD pin assignment

| SWD port name | Pin function                 | Pin assignment |
|---------------|------------------------------|----------------|
| SWCLK         | Serial clock input           | PA14           |
| SWDIO         | Serial data input and output | PA13           |

The PA13/PA14 pins can be configured as SWD function or GPIO/ISP function, and the function configuration is performed by the SWDIO bit field of the system control register SYSCTRL\_CR2. When SWDIO is 0, the PA13/PA14 pin is configured as SWD function; when SWDIO is 1, it is configured as GPIO/ISP function.

It is generally recommended to use a  $100 \text{K}\Omega$  pull-up resistor for the SWD pin. When the PA13/PA14 of the CW32W031 is used as the SWD function, there is a built-in pull-up resistor with a resistance value between  $50 \text{K}\Omega \sim 200 \text{K}\Omega$ . Users can add a pull-up resistor externally to improve the anti-interference performance.

The PA13/PA14 pin of the CW32W031 series is the SWD function by default. If the user has set the encryption level, it is necessary to judge whether the SWD function is supported according to the set level. The configuration and function of the SWD pin are shown in the following table:

Encryption levelSYSCTRL\_CR2.SWDIOPA13/PA14 functionLevel0/1 encryption0 (default)SWD function1GPIO/ISP functionLevel2 encryption0 (default)NA, no function1GPIO/ISP function0 (default)NA, no function

Table 26-2 SWD pin function

#### Cautions:

Level3 encryption

- 1. The encryption level can be set through the ISP communication method. For details, please refer to the ISP communication protocol document;
- 2. After the chip is powered on, both SWDIO and SWCLK are internal pull-ups by default, and users do not need to connect external pull-up resistors;
- 3. When the chip encryption level is set to 2, the SWD function is disabled and can only be programmed by ISP;
- 4. When the chip encryption level is set to 3, the SWD function and the ISP function are disabled, and the chip cannot be programmed with new programs again.

**GPIO** function

### 26.3 Debug communication protocol

The debugger and the DAP debug module of the target chip communicate through the SWD packet transmission protocol. The packet transmission protocol is a 2-wire synchronous serial protocol, using the SWCLK clock signal and the SWDIO data signal:

- SWCLK is a one-way clock signal, which is output by the debugger to the target chip
- SWDIO is a bidirectional data signal, which is driven by the debugger and the target chip bidirectionally time-sharing

The protocol defines the conversion time of the transceiver and the transceiver with a length of one SWCLK cycle. During the conversion time of the transceiver and the target chip, neither the debugger nor the target chip drives SWDIO, and SWDIO is pulled up to a high level by a pull-up resistor.

When transmitting data on the SWDIO signal line, follow the principle that the lowest LSB is transmitted first, and the highest MSB is transmitted last.

Through the packet transfer protocol, the debugger can read and write access to the DP register and AP register in the DAP debug module of the target chip, hereinafter referred to as SW-DP and SW-AP.

#### 26.3.1 Transmission protocol format

The DAP debug module includes the DP debug port register and the AP access port register. The communication between the debugger and the DAP debug module of the target chip is actually the read and write operations on the DP register and the AP register.

The transmission communication frame usually contains three fields:

- Package request
   The length is 8-bit, the debugger to the target chip;
- Response
   The length is 3-bit; the target chip to the debugger;
- Data transmission

The length is 33-bit, the target chip to the debugger or the debugger to the target chip, optional field.

The function definition of each request package is as follows:

Table 26-3 Definition of packet request bits

| Bit | Name         | Description                                                   |  |
|-----|--------------|---------------------------------------------------------------|--|
| 0   | Start up     | Must be 1                                                     |  |
| 1   | APnDP        | 0: DP access; 1: AP access                                    |  |
| 2   | RnW          | 0: Write request; 1: Read request                             |  |
| 3:4 | A[3:2]       | Address field of DP or AP register, bit3 is A2, bit4 is A3    |  |
| 5   | Parity check | Bit parity bit of the previous 5-bit                          |  |
| 6   | Stop         | 0                                                             |  |
| 7   | Reside       | Not driven by the host. Target chip reads as 1 due to pull-up |  |

The request packet is always followed by the conversion time of the transceiver (default 1bit). At this time, neither the master nor the target drives SWDIO.

The response bits transmitted by the target are defined as follows:

Table 26-4 Definition of target transmit response bits

| Bit | Name | Description                                                                                                   |
|-----|------|---------------------------------------------------------------------------------------------------------------|
| 0:2 | ACK  | 001: FAULT (bit0:0, bit1:0, bit2:1)<br>010: WAIT (bit0:0, bit1:1, bit2:0)<br>100: OK (bit0:1, bit1:0, bit2:0) |

After the ACK response is the conversion time of the transceiver (default 1bit), at this time, neither the master nor the target will drive SWDIO.

Data transmitted by the debugger or target chip, the bits are defined as follows:

Table 26-5 Definition of data transmission bits

| Bit  | Name           | Description                   |
|------|----------------|-------------------------------|
| 0:31 | WDATA or RDATA | Write or read data            |
| 32   | Parity check   | Bit parity bit of 32-bit data |

The data transmission phase is not necessary, and data transmission occurs only in the following two cases:

- The response received after the data read or write request is the OK response
- The ORUNDETECT flag bit of the DP-CTRL/STAT register is set to 1. At this time, no matter what kind of response (including WAIT and FAULT) is received, data transmission is required

#### 26.3.2 SW-DP state machine

There is an ID CODE register inside SW-DP with a fixed value of 0x0BB11477 (Cortex®-M0+ identification code of ARM company). Before using the SWD packet protocol to read and write the target register, the ID number must be read to activate the SW-DP logic of the target chip, otherwise the SW-DP state machine of the target chip will not work.

The operation sequence is as follows:

- Step 1: After power-on reset or after the SWDIO line is at a high level for more than 50 cycles, the SW-DP state machine enters the reset state;
- Step 2: After entering the reset state, keep the SWDIO line at a low level for at least 2 cycles, and the SW-DP state machine enters the idle state;
- Step 3: After entering the idle state, perform read access to the ID CODE register of DP-SW;

#### Caution:

If this operation is not performed, the target board will send a FAULT response in the subsequent packet communication response phase.

Step 4: Read and write access to the registers to be accessed according to the packet protocol.



#### 26.3.3 Read and write access for SW-DP and SW-AP

- Write access for SW-DP/SW-DP
  - After the debugger receives the ACK, the data must be transmitted immediately after the conversion time of 1 clock cycle.
- Read access for SW-DP
  - When the target chip is ready to transmit data, it transmits an OK response, and then transmits data immediately;
  - When the target chip DAP is not ready for data transmission, it transmits a WAIT response to end the communication;
  - When the DAP status of the target chip is wrong, a FAULT response is transmitted to end the communication.
- Read access for SW-AP
  - The read access to the AP is registered, that is, the read AP operation cannot return the required result, but the result of the read operation cannot be returned until the next AP operation. If the next access to be performed is not an AP read access operation, the DP-RDBUFF register must be read to obtain the result of this read operation.
- The READOK flag in the DP-CTRL/STAT register of the M0 core's debug control/status register is updated every time a SW-AP read access or DP-RDBUFF read request is made to indicate whether the AP read access is successful.
- SW-DP has write buffers (for SW-DP or SW-AP writes) that can accept the next write operation while the read and write operations are not complete. If the SW-DP's write buffer is full, the chip SW-DP logic will reply with a WAIT response to notify the host to suspend the operation. The exception is special operations such as IDCODE read, DP-CTRL/STAT read or ABORT write operations, which are also accepted when the write buffer is full.
- Since SWCLK and HCLK are not synchronous clocks and belong to the asynchronous clock domain, two additional SWCLK cycles are required after the write operation (after the parity bit of the data transmission) to ensure that the write operation takes effect. The SWDIO line should be driven low (idle state) while the master is driving these 2 SWCLK cycles. This is especially important when writing power-on request operations to the DP-CTRL/STAT registers, otherwise the next operation (one that is valid after the core is powered on) will be executed immediately and will fail.

### 26.3.4 SW-DP register

When APnDP is 0, access the DP register, which is addressed by A[3:2]. When the address is the same, the meaning of the register may be different due to different read and write operations, as shown in the following table:

Table 26-6 List and definition of DP registers

| A[3:2]              | Read/write             | R egister name                                                                                         | Register content description                                                                                                                                                                                                                                                           |
|---------------------|------------------------|--------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read 00             |                        | IDCODE                                                                                                 | Fixed at 0x0BB1 1477 (to identify SW-DP), ARM Cortex ® -M0+ identification code                                                                                                                                                                                                        |
|                     | Write                  | ABORT                                                                                                  | See Table 26-7 Definition of DP ABORT register bits                                                                                                                                                                                                                                    |
| 01                  | Read/write             | DP-CTRL/STAT<br>(SELECT.CTRLSEL = 0)                                                                   | Mainly used for:  1. Request system or debug power-on;  2. Configure transfer operation for AP access;  3. Control comparison and verification operations;  4. Read some status flags (overflow and power-up acknowledgment)                                                           |
|                     |                        | WIRE CONTROL<br>(SELECT.CTRLSEL = 1)                                                                   | Used to configure the physical serial port protocol (such as the duration of transition times, etc.)                                                                                                                                                                                   |
| Read<br>10<br>Write | READ RESEND            | Allow recovery of read data from corrupted debug transfers without repeating the original AP transfer. |                                                                                                                                                                                                                                                                                        |
|                     | Write                  | SELECT                                                                                                 | Used to select the current access AP port and the 4-word register BANK in the AP port. See <i>Table 26-8 DP SELECT register</i>                                                                                                                                                        |
| 11                  | Read/write READ BUFFER |                                                                                                        | Since an AP access has been issued, this read buffer is useful (providing the result of reading this AP request when executing the next AP transaction). This read buffer captures the data in the AP, displayed as the result of the previous read, without starting a new operation. |

Table 26-7 Definition of DP ABORT register bits

| Bit  | Name       | Description                                                                                                                                                                                      |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RESERVE    |                                                                                                                                                                                                  |
| 4    | ORUNERRCLR | Write 1 to clear the STICKYORUN error flag                                                                                                                                                       |
| 3    | WDATAERR   | Write 1 to clear the WDATAERR error flag                                                                                                                                                         |
| 2    | STICKYERR  | Write 1 to clear the STICKYERR error flag                                                                                                                                                        |
| 1    | STICKYCMP  | Write 1 to clear the STICKYCMP flag                                                                                                                                                              |
| 0    | DAPABORT   | Write 1 to generate the DAP ABORT signal and abandon the current access operation; when the target chip responds to the WAIT response, this operation must be performed to abort this operation. |

Table 26-8 DP SELECT register

| Bit   | Name      | Description                                                                                                                                          |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | APSEL     | Select the current AP port, fixed as b00000000                                                                                                       |
| 23:8  | RESERVE   |                                                                                                                                                      |
| 7:4   | APBANKSEL | Select the active 4-word register BANK on the current AP                                                                                             |
| 3:1   | RESERVE   |                                                                                                                                                      |
| 0     | CTRLSEL   | DP port register selection: The default is 0 after reset, select the CTRL/STAT register; Set to 1 to select the WCR register (Wire Control Register) |

### 26.3.5 SW-AP register

When APnDP is 1, access the AP register. Since there are many SW-AP registers, it is necessary to combine A[3:2] and the APBANKSEL bit field value of the SW-DP selection register SELECT to uniquely address the SW-AP register.

This article will not go into details about SW-AP one by one, but only introduces a common IDR public register (address 0xFC), as shown in the following table:

Table 26-9 AP IDR public register

| Bit   | Definition                                                                                                                                            |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | AP designed version Rervision.                                                                                                                        |
| 27:24 | AP designer identification code, this chip is fixed to 0x04.                                                                                          |
| 23:17 | AP designer identification code, this chip is fixed to 0x3B.                                                                                          |
| 16:13 | AP type. For example, the memory access port type identification code is b1000, and the undefined type access port type identification code is b0000. |
| 12:8  | Reserved                                                                                                                                              |
| 7:0   | AP ID. Such as MEM-AP or JTAG-AP and so on.                                                                                                           |

### 26.4 Kernel debugging

The core can be debugged by manipulating the core debug registers, and the debugger accesses these registers through DAP debugging.

The kernel debug registers mainly include 4 registers, as shown in the following table:

Table 26-10 Kernel debug registers

| Register | Description                                                                                                                                                                                                                              |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DHCSR    | Debug suspend control and status register, 32-bit, control processor suspend, single step and restart actions                                                                                                                            |
| DCRSR    | Debug kernel register selector register, 17-bit, controls reading and writing of kernel registers during suspend                                                                                                                         |
| DCRDR    | Debug kernel register data register, 32-bit, data transfer register for reading and writing kernel registers during pause                                                                                                                |
| DEMCR    | Debug exception monitoring control register, 32-bit, used to enable data watchpoint unit and vector capture feature, using vector capture, the debugger can suspend the processor when the processor is reset or a hardware error occurs |

These registers can only be reset by a power-on reset. See 《Cortex®-M0+ Technical Reference Manual》 for more details.

### 26.5 Breakpoint unit BPU

The Cortex®-M0+ BPU breakpoint unit provides four breakpoint registers to implement the PC pointer-based breakpoint function.

For more information on the identification registers and access types of the BPU CoreSight component, see 《ARMv6-M Architecture Reference Manual》 and the ARM® CoreSight Component Technical Reference Manual.

### 26.6 Data observation points and tracking DWT

Cortex ®- M0+ DWT provides two observation point register sets. Realize the following functions:

- Set data watchpoints:
  - Data or peripheral addresses can be marked as watch variables, and access to this address will generate a debug event and suspend program execution.
- Optional DWT program counter sampling register (DWT\_PCSR) feature in ARMv6-M. Allows the debugger to periodically sample the PC pointer, providing a rough analysis without stopping the processor.

See 《ARMv6-M Architecture Reference Manual》 for more information.



### 26.7 Debug components DBG

The debugger implements clock control support for peripherals such as timers, watchdogs, and RTCs during breakpoints through the debug components DBG. Through the setting of the debug state timer control register SYSCTRL\_DEBUG, you can control the timer, watchdog timer, RTC, etc. to run normally or pause during the breakpoint in the debug state, as shown in the following table:

Table 26-11 Debug status timer control register SYSCTRL\_DEBUG

| Bit    | Name    | Vaule | Counter function configuration during breakpoints in debug state  |
|--------|---------|-------|-------------------------------------------------------------------|
| 10     | WWDT    | 1     | In debug state, the WWDT counter pauses counting                  |
|        | WWDT    | 0     | In debug state, the WWDT counter counts normally                  |
| 9      | IWDT    | 1     | In debug state, the IWDT counter pauses counting                  |
| 9      | וטאוו   | 0     | In debug state, the IWDT counter counts normally                  |
| 0      | 8 RTC   | 1     | In debug state, the RTC counter pauses counting                   |
| 8      |         | 0     | In debug state, the RTC counter counts normally                   |
|        | A\A/T   | 1     | In debug state, the AWT counter pauses counting                   |
| 6      | AWT     | 0     | In debug state, the AWT counter counts normally                   |
| 5      | DTIM122 | 1     | In debug state, the BTIM1, BTIM 2, BTIM 3 counters pause counting |
| 5      | BTIM123 | 0     | In debug state, the BTIM1, BTIM 2, BTIM 3 counters count normally |
| 2      | 2 GTIM2 | 1     | In debug state, the GTIM2 counter pauses counting                 |
| 2      |         | 0     | In debug state, the GTIM2 counter counts normally                 |
| 1 GTIM | CTIM1   | 1     | In debug state, the GTIM1 counter pauses counting                 |
|        | GIIMIT  | 0     | In debug state, the GTIM1 counter counts normally                 |
| 0      | ATIM    | 1     | In debug state, the ATIM counter pauses counting                  |
|        |         | 0     | In debug state, the ATIM counter counts normally                  |

For example, when the timer outputs PWM for motor control, the timer cannot be stopped, otherwise the motor will be damaged. For another example, the watchdog timer should stop counting during the breakpoint to prevent an undesired reset of the system.

#### 26.8 Cautions

CW32W031 needs to use HCLK for debugging connection during debugging. It is not allowed to turn off HCLK during the debugging session. Therefore, executing WFI in the debugging environment will turn off the kernel HCLK, causing the debugging function to fail.

If the target chip has entered the DeepSleep mode, the DAP hardware debugging module does not work at this time, the debugger cannot connect with the DAP hardware debugging module of the target chip, and the debugging function cannot be realized.

The user must ensure that the chip is in Active mode or Sleep mode to use the debugger for debugging.

Therefore, it is recommended that users complete all functional debugging of the device in non-DeepSleep mode before merging the relevant code of deep sleep, and then debug the code related to deep sleep.

§ Digital signature CW32W031

## 27 Digital signature

#### 27.1 Overview

The digital signature is mainly used to store information such as the unique identification (UID) of the chip, product model, FLASH capacity, SRAM capacity, and the number of pins in the chip package, which can be read by SWD or CPU. The digital signature-related information is programmed at the factory, and user firmware or external devices can verify the legitimacy of the chip by reading the digital signature.

### 27.2 Product Unique Identification (UID) register (80bit)

The UID register stores the unique identifier of the chip, and its address is 0x0010 0A10 - 0x0010 0A19, a total of 80 bits. The UID is written during chip production and cannot be modified by the user. UID registers support reading in single-byte/half-word/full-word, etc., and then concatenated using custom algorithms.

Typical application scenarios of unique identifiers:

- Used as device serial number
- Device legitimacy verification to prevent piracy

When the device is produced, the user uses the private key to encrypt the UID, and stores the calculation result in the main FLASH memory or OTP memory. If the result is compared with the previously stored calculation result, it is considered that the device is legal, otherwise the program will not start, which can effectively prevent the user's device from being illegally copied (piracy).

- Used as a security key
  - Combined with UID and private algorithm, users can perform security verification before users program FLASH to improve the security of the code in FLASH.
- Activate the secure boot process, etc.

### 27.3 Product model register

The product model register stores the ASCII code of the product model, and its address is 0x0010 0A24 - 0x0010 0A39, with a total of 22 bytes. When the product model is less than 22 bytes, it is filled with 0x00.

For example, the model of the chip is CW32W031R8U6-QFN64, the corresponding data stored (starting from the low address) is: 0x43 0x57 0x33 0x32 0x57 0x30 0x33 0x31 0x52 0x38 0x55 0x36 0x2D 0x51 0x46 0x4E 0x36 0x34 0x00 0x00 0x00 0x00.

#### Caution:

If there are letters in the product model, the letters need to be capitalized.

### 27.4 FLASH capacity register

The FLASH capacity register stores the capacity of the built-in FLASH memory of the chip, and its address is 0x0010 0A3C - 0x0010 0A3F, a total of 4 bytes.

The FLASH capacity size read from the FLASH capacity register is in bytes, such as 0x0001 0000 for 64KB, and 0x0000 8000 for 32KB.



570 / 572 Rev 1.0

§ Digital signature CW32W031

### 27.5 SRAM capacity register

The SRAM capacity register stores the capacity of the built-in SRAM memory in the chip, and its address is 0x0010 0A40 - 0x0010 0A43, a total of 4 bytes.

The SRAM capacity size read from the SRAM capacity register is in bytes, such as 0x0001 0000 for 64KB, and 0x0000 4000 for 16KB.

## 27.6 Pin number register

The pin number register stores the chip pin number, its address is 0x0010 0A3A - 0x0010 0A3B, a total of 2 bytes. For example, 0x0020 represents 32Pin, and 0x0030 represents 48Pin.



§ Revision history CW32W031

# 28 Revision history

Table 28-1 Document revision history

| Date         | Revision | Changes          |
|--------------|----------|------------------|
| May 18, 2023 | Rev 1.0  | Initial release. |
|              |          |                  |
|              |          |                  |
|              |          |                  |
|              |          |                  |
|              |          |                  |
|              |          |                  |
|              |          |                  |
|              |          |                  |
|              |          |                  |
|              |          |                  |